若要在子过程P1调用后返回两个变量的结果,下列过程定义语句中有效的是( )。

admin2013-01-07  53

问题 若要在子过程P1调用后返回两个变量的结果,下列过程定义语句中有效的是(    )。

选项 A、Sub P1(n,m)
B、Sub P1(ByVal n,m)
C、Sub P1(n,ByVal m)
D、Sub P1(ByVal n,ByVal m)

答案A

解析 在VBA的过程调用时,参数有两种传递方式:传址传递和传值传递。如果在过程声明时形用ByVal声明,说明此参数为传值调用,此时参数的变化不会返回到实参;若用ByRef声明,说明此参数为传址调用,此时形参的变化将会返回到实参;没有说明传递类型,则默认为传址传递。由于本题要求可以返回两个变量的结果。所以应该使用传址调用,不能出现传值调用。也就是不能出现使用ByVal声明的形参。
转载请注明原文地址:https://kaotiyun.com/show/Skup777K
0

最新回复(0)