所谓全局变量,其实就是相对于局部变量而说的。全局变量是定义在整个文件层次上的,可以在文件内的任何地方被访问,包括函数内部。
DEFAULT_DB_NAME= "ss"
def get_connection():
print(DEFAULT_DB_NAME)
if __name__ == '__main__':
get_connection()
输出结果:
ss
但是当我改写程序如下:
DEFAULT_DB_NAME= "ss"
def check_dbname(db_name):
DEFAULT_DB_NAME += db_name
print(DEFAULT_DB_NAME)
if __name__ == '__main__':
check_dbname('aa')
这时候程序竟然报错了!
UnboundLocalError: local variable ‘DEFAULT_DB_NAME’ referenced before assignment
这是因为作为全局变量,我们不能在函数内部随意改变它的值。如果一定要在函数内部改变全局变量的值,就必须加上global这个声明。代码如下:
DEFAULT_DB_NAME= "ss"
def check_dbname(db_name):
global DEFAULT_DB_NAME
DEFAULT_DB_NAME += db_name
print(DEFAULT_DB_NAME)
if __name__ == '__main__':
check_dbname('aa')
这里的 global 关键字,并不表示重新创建了一个全局变量 DEFAULT_DB_NAME,而是告诉 Python 解释器,函数内部的变量 DEFAULT_DB_NAME,就是之前定义的全局变量,并不是新的全局变量,也不是局部变量。这样,程序就可以在函数内部访问全局变量,并修改它的值了。
好,我们再看一段代码:
DEFAULT_DB_NAME= "ss"
def check_dbname(db_name):
DEFAULT_DB_NAME = db_name
print(DEFAULT_DB_NAME)
if __name__ == '__main__':
check_dbname('aa')
输出结果:
aa
猛地一看,特别是之前搞过java或者go的同学,这不是在函数内部也能修改全部变量吗,根本就不需要加global啊!那么事实是这样吗?
其实在函数内部的DEFAULT_DB_NAME 其实是个重新定义的局部变量。这里有个原则:
函数内部局部变量和全局变量同名的情况,那么在函数内部,局部变量会覆盖全局变量。