byref和byval:一文读懂按地址传递(默认)和按值传递——vba

在vba中,经常用地调用子程序,参数传递分为:

byref ,被调用程序 按地址传递,传回主程序的参数,回调时会受影响。

按地址传递(ByRef),是指主程序直接将数据交给子过程(过程中定义传递方式),在过程中修改、调试、返回给主程序,主程序输出的是修改后的值。

VBA默认的是 byref方式

byval ,被调用程序 按值传递,传回主程序的参数,回调时会不受改变。

按值传递(Byval),是指将主程序的值(副本一份)给子过程,过程对副本操作,主程序输出的仍是原值。若想输出值传递后的值,可在子过程中设置输出。

代码如下:

复制代码
Sub test1(ByRef a)
a = a + 1
End Sub
 
Sub test2(ByVal b)
b = b + 1
End Sub
 
Sub main1()
'yngqq@2024年4月16日10:46:28
x = 1
y = 1
test1 x
test2 y
MsgBox "x=1,  y=1,调用子程序后:" & vbCr & "x=" & x & "    y=" & y
End Sub

运行结果:

由此可见,byref会修改主程序变量值,而byval不会改变主程序变量值。

相关推荐
你的冰西瓜8 小时前
C++中的priority_queue容器详解
开发语言·c++·stl
H Corey8 小时前
Java字符串操作全解析
java·开发语言·学习·intellij-idea
1314lay_10078 小时前
color: var(--el-color-success); CSS里面使用函数
前端·css
brucelee1868 小时前
Java 开发AWS Lambda 实战指南(SAM CLI + IntelliJ)
java·开发语言
xlq223228 小时前
16.环境变量与地址空间
前端·chrome
tobias.b8 小时前
408真题解析-2010-37-计算机网络-子网划分与CIDR
开发语言·计算机网络·计算机考研·408真题解析
纯.Pure_Jin(g)8 小时前
【Python练习五】Python 正则与网络爬虫实战:专项练习(2道经典练习带你巩固基础——看完包会)
开发语言·vscode·python
hoiii1878 小时前
基于C#实现的高性能实时MP4录屏方案
开发语言·c#
JasonSJX8 小时前
海海软件正式发布全新 DRM-X官网 Next.js 重构、多语言升级与 SEO 优化,助力全球数字版权保护
开发语言·javascript·安全·重构·视频防录屏·开源drm·加密保护课程