l = []
d = {}
def add_value():
d[‘frank‘] = ‘yangcaho‘
l.append(d)
add_value()
print(l)
print(d)
输出:
[{‘frank‘: ‘yangcaho‘}]
{‘frank‘: ‘yangcaho‘}
l = []
d = {}
def add_value():
global l
global d
d[‘frank‘] = ‘yangcaho‘
l.append(d)
add_value()
print(l)
print(d)
输出:
[{‘frank‘: ‘yangcaho‘}]
{‘frank‘: ‘yangcaho‘}
a = ‘frank‘
def add_value():
global a
a = ‘yangchao‘
add_value()
print(a)
yangchao
a = ‘frank‘
def add_value():
b = a + ‘yangchao‘
print(b)
add_value()
print(a)
frankyangchao
frank
结论:可以使用定义在函数外的全局变量的值(假设在函数内没有同名的变量)。但强烈建议尽量避免这样做,因为这使得程序的读者会不清楚这个变量是在哪里定义的。使用global语句可以清楚地表明变量是在外面的块定义的。
可变对象如list的.paaend()操作与‘+’操作,的一些不同点。
l = [‘frank‘, ‘liuilu‘] print(id(l)) L = l + [‘yangchao‘] print(id(L)) print(l) print(id(l)) 36364616 36365960 [‘frank‘, ‘liuilu‘] 36364616
l = [‘frank‘, ‘liuilu‘] print(id(l)) l += [‘yangchao‘] print(l) print(id(l)) 43639112 [‘frank‘, ‘liuilu‘, ‘yangchao‘] 43639112
l = []
d = {}
def add_value():
for i in range(1, 3):
print(‘第%s次循环‘ %i)
d[‘age‘] = i
print(d)
print(‘#‘ * 10)
print(l)
print(‘#‘ * 10)
l.append(d)
print(l)
add_value()
输出结果
第1次循环
{‘age‘: 1}
##########
[]
##########
[{‘age‘: 1}]
第2次循环
{‘age‘: 2}
##########
[{‘age‘: 2}]
##########
[{‘age‘: 2}, {‘age‘: 2}]
但是函数内如果是用赋值的方式(如下面两种模式),那么函数中的d就不再是全局变量中的d了。所以有了每次赋值操作(即’=‘),每次append的d都是新的值。不会改变原来的值。
l = []
d = {}
def add_value():
for i in range(1, 3):
print(‘第%s次循环‘ %i)
d = {‘age‘, i}
print(d)
print(‘#‘ * 10)
print(l)
print(‘#‘ * 10)
l.append(d)
print(l)
add_value()
第1次循环
{1, ‘age‘}
##########
[]
##########
[{1, ‘age‘}]
第2次循环
{2, ‘age‘}
##########
[{1, ‘age‘}]
##########
[{1, ‘age‘}, {2, ‘age‘}]
l = []
def add_value():
for i in range(1, 3):
d = {}
print(‘第%s次循环‘ %i)
d[‘age‘] = i
print(d)
print(‘#‘ * 10)
print(l)
print(‘#‘ * 10)
l.append(d)
print(l)
add_value()
第1次循环
{‘age‘: 1}
##########
[]
##########
[{‘age‘: 1}]
第2次循环
{‘age‘: 2}
##########
[{‘age‘: 1}]
##########
[{‘age‘: 1}, {‘age‘: 2}]
a = []
b = []
c = {}
d = {}
e = ‘frank‘
f = ‘frank‘
print(id(a), id(b), id(c), id(d), id(e), id(f))
43770760 43770824 31284896 31284968 31302408 31302408
可见每次创建一个空的可变对象时,都会重新开辟内存,但不可变对象就是指向原来的的地址空间。
原文:https://www.cnblogs.com/yc3110/p/10625235.html