VBA 模块级变量和过程级变量,全局变量,局部变量,end,exit end sub等影响

一个SUB内变量尽量要独立,因为所有变量都在sub生效

 

 

1、全局变量在整个工程文件内都有效;

2、静态全局变量只在定义它的文件内有效;

3、静态局部变量只在定义它的函数内有效,且程序仅分配一次内存,函数返回后,该变量不会消失;局部变量在定义它的函数内有效,但是函数返回后失效。
4、全局变量和静态变量如果没有手工初始化,则由编译器初始化为0。局部变量的值不可知。

5、静态局部变量与全局变量共享全局数据区,但静态局部变量只在定义它的函数中可见。静态局部变量与局部变量在存储位置上不同,使得其存在的时限也不同,导致对这两者操作 的运行结果也不同。

https://blog.csdn.net/Littlehero_121/article/details/88634153

 

 

  • Public和Private只能在过程外使用,用来定义模块级变量,区别是Public定义的模块级变量对外界可见,可以被本模块和其他模块使用。而Private定义的模块级变量,只能用于本模块,不能被其他模块调用。
  • Dim可以用于过程内部和外部,但不管用于过程内外,使用Dim语句定义的变量均为私有,无法在模块外使用;
  • Static只能在过程内部定义静态变量,由Static定义的变量只能用于本过程,不能被本模块的其他Sub或Function调用,更不能被其他模块调用。

 

跨模块级
public  (只能定义在过程外)


模块级
public    (只能定义在过程外)
private   (只能定义在过程外)
dim   

过程级
dim
static   (只能定义在过程内)

 

 

 

先把代码写着,一会不全

局部变量

dim k 

 这种其他sub无法

Dim j
Public k
Private l


Sub test01()
Static m

j = 1
k = 0
l = 3
m = 5

For i = 1 To 5
   k = i * i
   Debug.Print k
Next

End Sub


Sub test02()

Debug.Print k
End Sub


Sub test03()

test01
Debug.Print k
Debug.Print j
Debug.Print l
Debug.Print m

End Sub

 

'同一个sub里,不要用重复的变量名!

为啥循环完了,i=6了?

Dim j
Public k
Private l


Sub test01()
Static m

j = 1
k = 0
l = 3
m = 5

For i = 1 To 5
   k = i * i
   Debug.Print "i=" & i; "  ";
   Debug.Print "k=" & k
Next

'为毛i=6了?
Debug.Print "i=" & i
Debug.Print "i=" & i
Debug.Print "i=" & i

'同一个sub里,不要用重复的变量名!
x = i + 1
Debug.Print "x=" & x


End Sub


Sub test02()

Debug.Print k
End Sub


Sub test03()

test01
Debug.Print k
Debug.Print j
Debug.Print l
Debug.Print m
End Sub

 

 

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值