Access中VBA编程问题
窗体中有命令按钮Command1,事件过程如下:PublicFunctionf(xAsInteger)AsIntegerDimyAsIntegerx=20y=2f=x*y...
窗体中有命令按钮Command1,事件过程如下:
Public Function f(x As Integer) As Integer
Dim y As Integer
x = 20
y = 2
f = x * y
End Function
Private Sub Command1_Click()
Dim y As Integer
Static x As Integer
x = 10
y = 5
y = f(x)
Debug.Print x; y
End Sub
运行程序,单击命令按钮,则立即窗口中显示的内容是( )。
A) 10 5
B) 10 40
C) 20 5
D) 20 40
参考答案:D
【解析】本题考查的是变量的作用域,程序中命令按钮中的x是用static定义的局部静态变量,只在模块的内部使用,过程执行时才可见。当调用f函数时,所求的f函数的值是f函数中x和y的值乘积,即f函数的值是2*20=40,调用f函数后,原命令按钮中x的值被f函数的值覆盖,即x=20,。最后输出x=20,y=40,故答案为D)。
请帮忙用通俗的语言把这一整道题目的意思翻译和解释一下! 谢谢!答案解释看不懂。。。
不要答案,答案我知道,我要的是对整道题目的解释,比如各个代码是什么意思?谢谢! 展开
Public Function f(x As Integer) As Integer
Dim y As Integer
x = 20
y = 2
f = x * y
End Function
Private Sub Command1_Click()
Dim y As Integer
Static x As Integer
x = 10
y = 5
y = f(x)
Debug.Print x; y
End Sub
运行程序,单击命令按钮,则立即窗口中显示的内容是( )。
A) 10 5
B) 10 40
C) 20 5
D) 20 40
参考答案:D
【解析】本题考查的是变量的作用域,程序中命令按钮中的x是用static定义的局部静态变量,只在模块的内部使用,过程执行时才可见。当调用f函数时,所求的f函数的值是f函数中x和y的值乘积,即f函数的值是2*20=40,调用f函数后,原命令按钮中x的值被f函数的值覆盖,即x=20,。最后输出x=20,y=40,故答案为D)。
请帮忙用通俗的语言把这一整道题目的意思翻译和解释一下! 谢谢!答案解释看不懂。。。
不要答案,答案我知道,我要的是对整道题目的解释,比如各个代码是什么意思?谢谢! 展开
3个回答
展开全部
Static x As Integer 即便X是汪橡静态函数, 那又能怎么样, 在函数亩樱f(x) 中 x 又被强制覆盖了 是20 而不是10 ,y又被强制覆盖了 是2 而不是5 , 函数输出结果当然是 40了
答案就是 D
这个除非是用于考试的题目,实际程序应用中没有这样用的, 应该说这个的题目就是困耐旁让你 辨别 函数作用点是用于考试的.
比如可以如下应用
Public Function f(x As Integer, y As Integer) As Integer
f = x * y
End Function
Private Sub Command1_Click()
Dim y As Integer
Static x As Integer
y = 5
y = f(x, y)
Debug.Print x; y
x = x + 10
End Sub
答案就是 D
这个除非是用于考试的题目,实际程序应用中没有这样用的, 应该说这个的题目就是困耐旁让你 辨别 函数作用点是用于考试的.
比如可以如下应用
Public Function f(x As Integer, y As Integer) As Integer
f = x * y
End Function
Private Sub Command1_Click()
Dim y As Integer
Static x As Integer
y = 5
y = f(x, y)
Debug.Print x; y
x = x + 10
End Sub
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询