VBA Object对象的函数参数传递
时间:2022-07-22
本文章向大家介绍VBA Object对象的函数参数传递,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
VBA的函数参数传递方式是Byval和Byref,数值类型、Stirng等那些值类型的是要非常注意用哪种方式的。对于Object对象引用类型的一直都说2种方式完全没有区别。
Object对象的Byval和Byref参数真的没有区别吗?
对于操作的这个Object对象来说,可以认为是没有区别,但是传递过程和其他数据类型的参数传递是一样的,遵守的规则并没有改变。
- ByVal 参数传递的时候,会在内存中另外复制一份,函数操作这个副本和传递之前的那个变量已经没有了任何关系;
- Byref 会把参数的内存地址传递给函数,函数接收到这个是通过内存地址来读取或者改写的,操作的就是原来的变量。
对于Object对象,其实我们传递的只是他的指针,也就是VarPtr得到的那个数字,是指向Object所在内存的地址。
可以理解为参数其实就是一个LongPtr类型,所以你是复制一份这个LongPtr类型的数字传递,还是把这个LongPtr类型所在的内存地址传递给函数,对于Object这个对象来说,是没有区别的。它最终都要通过这个数字所代表的内存地址找到Object对象。
Sub TestObject()
Dim rng As Range
Set rng = Range("A1")
Dim VarPtr中保存的数据 As Long
CopyMemory VarPtr(VarPtr中保存的数据), VarPtr(rng), 4
Printf "VarPtr(rng) = x0%x, ObjPtr(rng) = 0x%x, VarPtr中保存的数据 = 0x%x", VarPtr(rng), ObjPtr(rng), VarPtr中保存的数据
TestObjectByVal rng
TestObjectByValByRef rng
End Sub
Function TestObjectByVal(ByVal rng As Range)
Dim VarPtr中保存的数据 As Long
CopyMemory VarPtr(VarPtr中保存的数据), VarPtr(rng), 4
Printf "ByVal: VarPtr(rng) = x0%x, ObjPtr(rng) = 0x%x, VarPtr中保存的数据 = 0x%x", VarPtr(rng), ObjPtr(rng), VarPtr中保存的数据
End Function
Function TestObjectByValByRef(ByRef rng As Range)
Dim VarPtr中保存的数据 As Long
CopyMemory VarPtr(VarPtr中保存的数据), VarPtr(rng), 4
Printf "ByRef: VarPtr(rng) = x0%x, ObjPtr(rng) = 0x%x, VarPtr中保存的数据 = 0x%x", VarPtr(rng), ObjPtr(rng), VarPtr中保存的数据
End Function
输出:
VarPtr(rng) = x022edd0, ObjPtr(rng) = 0xfaaddd0, VarPtr中保存的数据 = 0xfaaddd0
ByVal: VarPtr(rng) = x022ecc0, ObjPtr(rng) = 0xfaaddd0, VarPtr中保存的数据 = 0xfaaddd0
ByRef: VarPtr(rng) = x022edd0, ObjPtr(rng) = 0xfaaddd0, VarPtr中保存的数据 = 0xfaaddd0
从打印输出可以看出,Byval传递需要复制参数,其实只是把保存对象地址的那个内存地址,也就是VarPtr得到的那个地址复制改变了,而这个地址中保存的数据仍然是ObjPtr的那个地址。
- Highcharts AJAX JSON JQuery 实现动态数据交互显示图表 柱形图
- 企业支付宝账号开发接口教程--JAVA-UTF-8(实际操作------SpringMVC+JSP)
- 用pandas 进行投资分析
- 【专业技术】android 应用程序如何获取root权限
- Nginx+Keepalived(双机热备)搭建高可用负载均衡环境(HA)
- SpringMVC+MongoDB+Maven整合(微信回调Oauth授权)
- ZeroClipboard实现多个浏览器兼容的复制文本到剪贴板的功能
- Shiro 权限框架使用总结
- Apriori算法介绍(Python实现)
- linux学习第六十二篇:添加自定义监控项目,配置邮件告警,测试告警,不发邮件的问题处理
- Entity Framework Core 2.0 入门
- Nodejs开发框架Express3.0开发手记–从零开始
- 使用 nvm 管理不同版本的 node 与 npm
- svg矢量图绘制以及转换为Android可用的VectorDrawable资源
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 内容安全策略( CSP )
- [译] 优化 React APP 的 10 种方法
- 如何免登陆观看b站大会员番剧
- 聊聊越来越火的对象存储
- AJAX的基本原理及实例解析。
- Docker私有镜像仓库是什么?
- React Native布局详细指南
- 走进Golang之Context的使用
- 「Workshop」第十一期:降维
- 开始在 GitHub 上写博客
- 微信公众号菜单点击发送天气预报
- SAP CRM Fiori应用如何启用Sales Office和Sales Group两个字段
- 通过注册表调整 Windows 8 窗口边框宽度
- 在 Mac OS X 中创建和使用内存盘
- Mono for Android 下的 ListActivity