在窗体上画一个命令按钮,其名称为Commandl,然后编写如下程序:Private Sub Commandl_click()Dim a(10) As IntegerDim x As IntegerFor i=1 To 10a(i) =INext Ix=1MsgDox a(f(x) +x)End SubFunction f(y As Integer)y=y+2End Function程序运行后,单击命令按钮,消息框的输出结果为 1
  • 1、
【正确答案】 1、正确答案:6    
【答案解析】解析: 本题考查VBA中参数传递的知识。在VBA的过程调用时,参数有两种传递方式:传址传递和传值传递。如果在过程声明时形参用ByVal声明,说明此参数为传值调用,此时形参的变化不会返回到实参;若用ByRef声明,说明此参数为传址调用,此时形参的变化将会返回到实参;没有说明传递类型,则默认为传址传递。本题中的函数f的形参y没有使用ByVal声明,则默认为传址传递。当求a(f(x)+x)的值的时候,先要求出f(x)+x的值。由于x的值为1,那么调用函数f以后得到f(x)的返回值为3,同时由于函数f中改变了形参y的值