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

您所在的位置:网站首页 vba中的if可以与数组混合使用吗 VBA 模块级变量和过程级变量,全局变量,局部变量,end,exit end sub等影响

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

2023-12-19 10:14| 来源: 网络整理| 查看: 265

一个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

 

 



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3