http://www.cnblogs.com/phoebus0501/archive/2011/01/18/1938728.html
应该尽量避免使用全局变量, 因为:
1) 不同的模块都可以自由的访问全局变量,可能会导致全局变量的不可预知性。
对全局变量,如果程序员甲修改了_a的值,程序员乙同时也要使用_a,这时可能导致程序中的错误。这种错误是很难发现和更正的。
2) 全局变量降低了函数或模块之间的通用性,不同的函数或模块都要依赖于全局变量。
同样,全局变量降低了代码的可读性,阅读者可能并不知道调用的某个变量是全局变量。
但是某些时候,全局变量能够解决局部变量所难以解决的问题。事物要一分为二。
python中全局变量的使用:
1 声明法
1) 在文件开头声明全局变量: VAR = 0 (将全局变量大写便于识别)
2) 在具体函数中使用该变量时,需要事先声明 global VAR, 否则系统将该变量视为局部变量。
VAR = 10 #声明全局变量
def get_var() :
global VAR #声明变量为global
print VAR,
VAR += 1
if __name__ == ‘__main__‘ :
for i in range(5):
get_var()
#Result:
# 10 11 12 13 14
2 模块法(推荐)
1) 把全局变量定义在一个单独的模块中:
#global.py
GLOBAL_1 = 1
GLOBAL_2 = 2
GLOBAL_3 = ‘Hello World‘
2) 然后在另一个模块中导入全局变量定义模块,在新模块中使用全局变量:
import globalValues
def printGlobal():
print(globalValues.GLOBAL_1)
print(globalValues.GLOBAL_3)
globalValues.GLOBAL_2 += 1 # modify values
if __name__ == ‘__main__‘:
printGlobal()
print(globalValues.GLOBAL_2)
第二种方法,适用于不同文件之间的变量共享,而且一定程度上避免了开头所说的全局变量的弊端,推荐!