VBA中方法传参

时间:2021-02-24 00:33:35

将变量做为参数传递给方法

 Sub Test()
Dim a As Integer
a =
Add a
Debug.Print a '引用传递,a的值发生了变化,输出101
End Sub Function Add(a As Integer)
a = a +
End Function

结论:VB传参时默认是引用传递byRef。

使用byVal关键字强制形参为值传递

 Sub Test()
Dim a As Integer
a =
Add a
Debug.Print a '值传递,a的值没有变化,输出1
End Sub Function Add(ByVal a As Integer)
a = a +
End Function

调用一个有返回值函数

 Sub Test()
Dim a As Integer
a =
Dim sum As Integer
sum = Add(a)
Debug.Print sum '引用传递,输出101
End Sub Function Add(a As Integer) As Integer
Add = a +
End Function

认识“()”

 Sub Test()
Dim a As Integer
a =
Add (a)
Debug.Print a 'a的值没有变化,输出1
End Sub Function Add(ByRef a As Integer) As Integer
a = a +
End Function

解释:

    1、Add只有一个参数,并且是“过程式调用”方式的时候,VBE“偷偷”把代码自动改为了Add   (a)。注意,Add和(a)之间有个“空格”

    2、()在此有完全不同的意义,可以理解它是一个运算符。(a)生成了一个临时变量,a的一个副本,然后将这个临时变量(a)传递给Add

    3、a本身并没有传递给Add方法,所以a的值并不会有任何变化。

将一个数组做为参数传递给方法:

 Sub Test()
Dim arr() As Integer
arr() =
arr() =
arr() = showArray arr
Dim i As Integer
For i = To
Debug.Print arr(i) '输出101,102,103
Next i
End Sub Function showArray(arr() As Integer)
Dim i As Integer
For i = To
arr(i) = arr(i) +
Next i
End Function

和()有关的一个常见错误和保留问题:

 Sub Test()
Dim arr() As Integer
arr() =
arr() =
arr() = showArray (arr) '编译时报错:缺少数组或用户定义类型
Dim i As Integer
For i = To
Debug.Print arr(i)
Next i
End Sub Function showArray(arr() As Integer)
Dim i As Integer
For i = To
arr(i) = arr(i) +
Next i
End Function

      编译报错:缺少数组或用户定义类型,除了()生成了一个临时变量之外,与此有关的原因暂不明。。       

如果形参是arr而不是arr()

 Sub Test()
Dim arr() As Integer
arr() =
arr() =
arr() = showArray (arr)
Dim i As Integer
For i = To
Debug.Print arr(i) '输出1,2,3
Next i
End Sub Function showArray(arr)
Dim sum As Integer, i As Integer
For i = To
arr(i) = arr(i) +
Next i
End Function

VBA中方法传参的更多相关文章

  1. MyBatis dao层 方法传参

    MyBatis dao层 方法传参有三种方法. 1. 以下标的方法获取参数. <update id="insertSuccessKilled">       INSER ...

  2. 再谈Java方法传参那些事

    把一个变量带进一个方法,该方法执行结束后,它的值有时会改变,有时不会改变.一开始会觉得--“好神奇呀”.当我们了解java内存分析的知识后,一切都是那么简单明了了--“哦,这么回事呀”.但是今天的上机 ...

  3. 在Java中动态传参调用Python脚本

    最近,又接触到一个奇葩的接口,基于老板不断催促赶时间的情况下,在重写java接口和复用已有的python脚本的两条路中选择了后者,但是其实后者并没有好很多,因为我是一个对python的认识仅限于其名称 ...

  4. 对象引用 方法传参 值传递 引用传递 易错点 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  5. java的方法传参&comma;最容易混淆的问题&excl;&excl;&excl;

    参数传递 参数传递,可以理解当我们要调用一个方法时,我们会把指定的数值,传递给方法中的参数,这样方法中的参数就拥有了这个指定的值,可以使用该值,在方法中运算了.这种传递方式,我们称为参数传递. 在这里 ...

  6. vue 使用 axios 时 post 请求方法传参无法发送至后台

    axios 时 post 请求方法传参无法发送至后台报错如下 Response to preflight request doesn't pass access control check: No ' ...

  7. EasyUI queryParams属性 在请求远程数据同时给action方法传参

    http://www.cnblogs.com/iack/p/3530500.html?utm_source=tuicool EasyUI queryParams属性 在请求远程数据同时给action方 ...

  8. javascript 字符串方法传参

    javascript 字符串方法传参由于嵌套的单引号,双引号过多.有点混乱.. 正确方法如下: '   <td align="left"><input type= ...

  9. Python中的传参是传值还是传址?

    传值:在C++中,传值就是把一个参数的值给这个函数,其中的更改不会影响原来的值. 传址:即传引用,直接把这个参数的内存地址传递进去,直接去这个内存地址上进行修改. 但是这些在Python中都没有,Py ...

随机推荐

  1. mysql数据库开发常见问题及优化

    mysql 数据库是被广泛应用的关系型数据库,其体积小.支持多处理器.开源并免费的特性使其在 Internet 中小型网站中的使用率尤其高.在使用 mysql 的过程中不规范的 SQL 编写.非最优的 ...

  2. Web API返回JSON数据

    对Web API新手来说,不要忽略了ApiController 在web API中,方法的返回值如果是实体的话实际上是自动返回JSON数据的例如: 他的返回值就是这样的: { "Conten ...

  3. Java Socket常见异常处理 和 网络编程需要注意的问题

    在java网络编程Socket通信中,通常会遇到以下异常情况: 第1个异常是 java.net.BindException:Address already in use: JVM_Bind. 该异常发 ...

  4. mysql开启远程访问

    1.MySql-Server 出于安全方面考虑只允许本机(localhost, 127.0.0.1)来连接访问. 这对于 Web-Server 与 MySql-Server 都在同一台服务器上的网站架 ...

  5. ubuntu 13&period;04 64位安装32位兼容包

    未安装32位兼容包,编译出现未找到指定目录下gcc命令,则安装兼容包:sudo apt-get install ia32-libs 若提示:不能安装,与相关软件冲突,则按如下安装: 在网上找到更新源, ...

  6. Dynamics CRM2016 查询数据的三种方式的性能对比

    之前写过一个博客,对非声明验证方式下连接组织服务的两种方式的性能进行了对比,但当时只是对比了实例化组织服务的时间,并没有对查询数据的时间进行对比,那有朋友也在我的博客中留言了反映了查询的时间问题,一直 ...

  7. c&plus;&plus; &lowbar;pFirstBlock &equals;&equals; pHead

    今天写程序时碰到了这个异常,导致调试的程序卡死.在网上找了很久答案,都没解决.大致判定是对象被多次析构,但又确认程序逻辑没有问题. 后来参考了 http://www.cnblogs.com/qinta ...

  8. python dic字典使用

    #!/usr/bin/env python -*-''' 字典的基本组成及用法: dict={key:value} dict[key]=value 字典是无序的. key值是唯一属性,一对一,几个ke ...

  9. TempData ViewBag ViewData区别

    在这篇<MVC 5使用TempData Object跨视图传递数据>https://www.cnblogs.com/insus/p/3378016.html中,已经在评论回复网友:网上查找 ...

  10. Oracle&amp&semi;SQLServer中实现跨库查询

    一.在SQLServer中连接另一个SQLServer库数据 在SQL中,要想在本地库中查询另一个数据库中的数据表时,可以创建一个链接服务器: EXEC master.dbo.sp_addlinked ...