大家好,我们今日继续讲解VBA代码解决方案的第125讲内容:关键字ByVal和ByRef的作用。在上一节中我们讲到了形式参数和实际参数的定义,同时讲到了从实际参数传递给形式参数的过程中按值传递和按地址传递的不同。为了更好的说明按值传递和按地址传递的区别,我们把上节的程序做一些修正:在函数声明行去掉参数a前面的关键字ByVal,结果会怎样呢?代码如下:

Sub MynzNumbers_1()

Dim a As Integer, b As Integer, c As Integer

a = 10

b = 20

c = 30

MsgBox MyAverage_1(a, b, c) & " " & a & " " & b & " " & c

End Sub

Function MyAverage_1(a, ByVal b, ByVal c)

a = a + 60

MyAverage_1 = (a + b + c) / 3

End Function

大家想想这时的结果该是怎么样呢?如下面的截图:

函数的结果仍然相同,但是函数MsgBox显示的变量a的内容现在是70了。说明这时就改变了储存在变量a里的原始数值。

上面的过程如何理解呢?

① 每个要传递给函数过程(或子程序)的变量,都可能在接收时改变数值,是否需要保护变量的原始数值是非常重要的。

② VBA有两个关键字,提供是否认可改变变量内容的允许——ByRef和 ByVal,但要注意VBA默认地按地址(关键字ByRef)给函数过程(或子程序)传递信息,引用函数被调用时,函数参数会按地址传递数据。因此,如果函数改变了参数值,原始的数值就被改变了。

③ 在上面的例子中,函数MyAverage_1声明参数a的前面去掉了关键字ByVal时,你就会得到按地址传递参数的结果。如果你想要函数过程 改变原始数值,你不必专门在参数前加关键字ByRef,因为,变量数值的传递默认就是ByRef。

本节的最后我们再谈一下按值传递的过程是如何进行的,当你在参数名称前使用关键字ByVal时,这意味着VBA复制一份原始数据,然后将复制 值传递给函数,如果函数改变了参数的数值的话,原始数据依然不会变——只有复制值变化。这就是为什么函数MyAverage改变了变量a的数值,而它的原始值还保持不变了。

如果你对上述过程还是不清楚,我再做一个更加形象的说明:

①按址传递时,实质上实际参数是把指针(地址)传递给形式参数了,这时指针指向的地址的值即是实际参数,此时形式参数与实际参数分别有一个指针,但同时指向同一个地址。

②按数值递时,实质上实参是把复制后的数值传递给形参了,这个时候实际参数和形式参数具有不同的指针,形式参数的指针指向的地址是复制后数值的地址指针,此时实际参数的指针没有发生改变。

今日内容回向:

1 按值传递和按地址传递的关键字是什么?

2 如何理解两种传递过程中的指针不同?

c++builder传递参数_参数按值传递和按地址传递过程中,指向内存的指针如何变化?...相关推荐

  1. php数组时按值传递还是按地址传递

    php数组时按值传递还是按地址传递 一.总结 1.数组都是按值:php普通变量和数组的赋值(=)是按值传递,对象的赋值(=)是按址传递 2.对象和按值和按址:对象的clone(用clone关键字)是按 ...

  2. R语言使用单个向量创建矩阵数据、通过byrow参数指定从向量转化为矩阵的过程中的数据排布方式

    R语言使用单个向量创建矩阵数据.通过byrow参数指定从向量转化为矩阵的过程中的数据排布方式 目录 R语言使用单个向量创建矩阵数据.通过byrow参数指定从向量转化为矩阵的过程中的数据排布方式 R语言 ...

  3. python吃显卡还是内存不足_解决pytorch GPU 计算过程中出现内存耗尽的问题

    Pytorch GPU运算过程中会出现:"cuda runtime error(2): out of memory"这样的错误.通常,这种错误是由于在循环中使用全局变量当做累加器, ...

  4. java 中方法里的参数_【Java基础】12、java中方法的参数传递机制

    无论是什么语言,要讨论参数传递方式,就得从内存模型说起,主要是我个人觉得从内存模型来说参数传递更为直观一些.闲言少叙,下面我们就通过内存模型的方式来讨论一下Java中的参数传递. 这里的内存模型涉及到 ...

  5. fopen_s不接受两个参数_如何利用SPC来管理制造过程,不懂SPC还敢混“质”场?

    请点击上面 免费关注本账号! 必读 →  2019年4-5月开课计划(IASC-CN俱乐部) PC是汽车行业品质管理的重要工具之一,AIAG为此写了一整本书.这篇文章略去SPC一些基础知识的介绍,直接 ...

  6. 按值传递按引用传递按地址传递

    按值传递:不改变外部对象 按引用传递&&按地址传递:允许改变外部对象 #include <iostream> #include <cstdlib> #inclu ...

  7. Hadoop-2.8.0集群搭建、hadoop源码编译和安装、host配置、ssh免密登录、hadoop配置文件中的参数配置参数总结、hadoop集群测试,安装过程中的常见错误

    25. 集群搭建 25.1 HADOOP集群搭建 25.1.1集群简介 HADOOP集群具体来说包含两个集群:HDFS集群和YARN集群,两者逻辑上分离,但物理上常在一起 HDFS集群: 负责海量数据 ...

  8. 如何初始化局部变量c语言_【C语言更新】C语言中如何来定义一个指针,并且对其进行初始化...

    文/Edward上一节中,我们利用了一个小知识来介绍了一下指针,在上面这个例子中,小明和小丽手中的这个杯子就好比我们C语言中的变量,它确实是实实在在存放一些有具体意义的数据.这个杯套就类似于C语言中指 ...

  9. 怎么判断手机在抖动_集合来了!激光头切割过程中一直抖动、跳动、上下动是什么原因?...

    激光切割机在运行的时候激光头一直跟随抖动,或者是在切割的时候上下小幅度移动这到底是怎么回事呢?解决这个问题我们需要从设备参数设置方面一层一层严谨的进行筛查,所以,下面请认真观看判断路径,尽快解决问题. ...

最新文章

  1. 从源码分析DEARGUI之add_input_float和4
  2. 【Android】Context
  3. 美团架构师写的Java面试宝典_2019最新美团java面试题及答案
  4. ShardingSphere(四) 垂直分库配置搭建,实现写入读取
  5. 设计灵感|元素拼接的海报到底好看在哪里?
  6. 《SQL高级应用和数据仓库基础(MySQL版)》学习笔记 ·005【表的CRUD操作(DML语句)】
  7. Java秒杀系统实战系列~分布式唯一ID生成订单编号
  8. linux提升nvme性能,基于SPDK的NVMe SSD性能评估指南
  9. Security+ 学习笔记12 安全编码实践
  10. 移动办公正在让电子邮件系统变得更有趣
  11. Kconfig使用详解
  12. scrapy提高爬取速度
  13. 专为《巫师3》打造 次世代RedEngine 3引擎公布
  14. 六级考试-考前最后一背
  15. 电脑用计算机软件一直闪退,电脑软件打开后闪退或崩溃怎么办
  16. DeFi发币潮之下,散户真能赚到钱吗?
  17. 夯实JAVA基本之一 —— 泛型详解(1):基本使用
  18. 德国技术工人工资高吗
  19. SM2 原文签名与HASH签名实现区别
  20. LightBox -灯箱效果插件(非常漂亮)

热门文章

  1. 关于算法的时间复杂度和空间复杂度的总结
  2. freemarker的常用内建函数
  3. 20165301第十周课下补做
  4. (转载)Linux下pthread_once()函数
  5. Turbo C 2.0 集成调试器的使用方法
  6. main方法一定要放在public类当中吗?
  7. leetcode 2. 两数相加
  8. 工信部发布新能源车准入新规 9月1日起正式实施
  9. 北京大学启用人脸识别系统:学生“刷脸”入校
  10. c++/c SM4加密解密算法代码实现