2.1.8 Function过程,也就是我们经常提到的函数过程。对于函数,我给出了一个更为确切的定义,这个定义我在各个平台上均有发表和阐述,我给出的定义如下:
如果对于唯一性输入值value,输出(或者return)的值也具有唯一性(这种输入或者输出的值没有个数的限制),那么具有这种变化关系的输入和输出关系,就称为输出是输入的函数.
而Function函数过程就是特别强调的这种输入和输出的关系。返回值就是我们说的是输出。也就是在教程中我们说的Function过程是有返回值的过程。这点也是Function过程和Sub过程的最为显著的不同点。通常而言,我们可以利用Function过程建立自己的自定义函数。就如同工作表函数中的SUM,COUNT等等。
2.1.9 在函数的讲解中,我还给大家讲解了两个非常重要的概念。一是易失性函数,一是参数的传递方式。
易失性函数,我们在理解时间的时候,经常会出现难以表述的状况,如什么是过去,什么是现在,什么是未来?所谓过去的心不可得,现在的心不可得,未来的心不可得。这就是时间的易失,也就是时间在函数上的体现。例如,now函数表述的是现在,那么什么是现在呢?当你确认此刻是现在时,现在的时刻却已经悄然离去。所以您无法准确的描述现在的时刻。这就是函数的易失性。
在函数的讲解中,我们同时讲了如何将非易失函数转换为易失性函数,这些都可以在教程中找到答案。
2.1.10 学习的过程是无止境的。当我们学习到这里,VBA的基本知识点,录制宏,条件结构,循环结构,对象,事件等等都有了初步的认识,这里我们要对自己的能力进行第一次升华了。就是理解形参和实参。也就是参数的传递的方式了。
我们在看代码的运行的时候,往往是看到的现象,而本质是在后台运行的。我们要透过现象看本质,一切相皆是虚妄,如果能见诸相非相,那就是见到了事物的本质。形参和实参配合着内存的占用正是见证了这种参数的传递。形参是传递了值,实参是传递了内存的地址:
1) 按值传递ByVal:在过程被调用时,传递给形参的是调用过程中的相应实参的值,形参与实参各占有不同位置的储存空间,被调用过程在执行过程中,只是改变了形参变量的值,不会调用过程的实参值。在函数声明行在参数名称之前加上关键字ByVal。
2)按地址传递ByRef:就是当调用一个过程时,是把实参变量的内存地址(指针)传递给被调用过程的形参,也就是说形参与实参使用相同地址的内存单元。因此当在被调用过程中改变形参的值,就等于改变了实参的值。
以上的逻辑关系就是相与本质的关系,如果我们能跳出VBA的框框,把自己的思维放在更大范围内,很多难于理解的地方会迎刃而解。
2.1.11 按值的传递其实就是传递的值,这个时候,形参和实参占用不同的内存,如果参数的值发生改变时,只是形参的占用的内存发生了改变,而实参并没有改变。
如果是按地址传递是传递的地址指针,这个时候形参和实参的指针是指向同一位置的,形参改变的时候,形参的内存也会改变,实参也随之会发生改变。我们可以对照教程仔细的理解两者的关系,同时不要拘泥于VBA领域,这一点在我关于“类”的讲解中体现的更加明显。在类的讲解中会贯彻另一种思维,当然,类的教程是VBA的高级教程,我们的学习要循序渐进。
l如何学习VBA呢? 概括的说就是: 学习过程中要信、解、受、持,更要有回向的业力。无论您在学习的任何阶段,都要对照教程的知识点加持自己的实际工作,总会有丰厚的收获。