VBA中方法传参
将变量做为参数传递给方法
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中方法传参的更多相关文章
- MyBatis dao层 方法传参
MyBatis dao层 方法传参有三种方法. 1. 以下标的方法获取参数. <update id="insertSuccessKilled"> INSER ...
- 再谈Java方法传参那些事
把一个变量带进一个方法,该方法执行结束后,它的值有时会改变,有时不会改变.一开始会觉得--“好神奇呀”.当我们了解java内存分析的知识后,一切都是那么简单明了了--“哦,这么回事呀”.但是今天的上机 ...
- 在Java中动态传参调用Python脚本
最近,又接触到一个奇葩的接口,基于老板不断催促赶时间的情况下,在重写java接口和复用已有的python脚本的两条路中选择了后者,但是其实后者并没有好很多,因为我是一个对python的认识仅限于其名称 ...
- 对象引用 方法传参 值传递 引用传递 易错点 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- java的方法传参,最容易混淆的问题!!!
参数传递 参数传递,可以理解当我们要调用一个方法时,我们会把指定的数值,传递给方法中的参数,这样方法中的参数就拥有了这个指定的值,可以使用该值,在方法中运算了.这种传递方式,我们称为参数传递. 在这里 ...
- vue 使用 axios 时 post 请求方法传参无法发送至后台
axios 时 post 请求方法传参无法发送至后台报错如下 Response to preflight request doesn't pass access control check: No ' ...
- EasyUI queryParams属性 在请求远程数据同时给action方法传参
http://www.cnblogs.com/iack/p/3530500.html?utm_source=tuicool EasyUI queryParams属性 在请求远程数据同时给action方 ...
- javascript 字符串方法传参
javascript 字符串方法传参由于嵌套的单引号,双引号过多.有点混乱.. 正确方法如下: ' <td align="left"><input type= ...
- Python中的传参是传值还是传址?
传值:在C++中,传值就是把一个参数的值给这个函数,其中的更改不会影响原来的值. 传址:即传引用,直接把这个参数的内存地址传递进去,直接去这个内存地址上进行修改. 但是这些在Python中都没有,Py ...
随机推荐
- Java c3p0连接池之二
<?xml version="1.0" encoding="UTF-8"?> <!-- c3p0-config.xml文件配置 --> ...
- 总结运行SSIS包的几种方式
方式一: 在BIDS里直接跑. 这个BIDS指的就是SQL Server Business Intelligence Development Studio,对于.net开发者来说它就是Visual S ...
- 发布一款Github博客皮肤
Major是一款基于jekyll的皮肤,没有用hexo,原因是换机器后无法更新博客,但是可以用U盘考环境.总之很麻烦!折腾纠结好久,还是用jekyll!不用发布直接push文章即可,方便快捷.用的放心 ...
- linux启动时文件系统错误问题
linux开机启动时,文件系统错误(磁盘有坏轨或文件系统出现错误) 原因: 1.系统运行时,突然断电或不正常关机,导致文件系统错误(文件系统错误并不是硬件错误,而是软件数据的问题) ...
- C#压缩库SharpZipLib的应用
SharpZipLib是一个开源的C#压缩解压库,应用非常广泛.就像用ADO.NET操作数据库要打开连接.执行命令.关闭连接等多个步骤一样,用SharpZipLib进行压缩和解压也需要多个步骤. ...
- LAMP环境搭建
安装前说明: 先安装gcc gcc-c++ make 等 可用yum install -y gcc gcc-c++ make 也可以使用rpm安装不过需要注意依赖 1.安装apache 下载链接:ht ...
- 调优SQL思路
--调优SQL --sqlreview ->logshipping -> ag辅助副本 --查看正确的执行计划 打开实际的执行计划set statistics io on --查看错误的执 ...
- UI,切图,命名
APP切图流程和APP切图命名规范详细完整版 http://www.25xt.com/appdesign/7339.html Marketch
- DELPHI XE5 与SQLITE
最近一次使用DELPHI做项目是使用DELPHI2009,为了访问本地数据库方便,使用ACCESS数据库,不需要安装驱动,(WINDOWS自带),但是ACCESS数据库的性能确实很糟糕,通过ADO连接 ...
- AngularJs的UI组件ui-Bootstrap
http://www.cnblogs.com/pilixiami/p/5597634.html