def func(val1):
print('val1: {}, id: {}'.format(val1, id(val1))) # val1: [1, 2, 3], id: 43499976
val2 = val1
print('val2: {}, id: {}'.format(val2, id(val2))) # val2: [1, 2, 3], id: 43499976
val2.append(4)
print('val2: {}, id: {}'.format(val2, id(val2))) # val2: [1, 2, 3, 4], id: 43499976
val2 = val2 + [5]
print('val2: {}, id: {}'.format(val2, id(val2))) # val2: [1, 2, 3, 4, 5], id: 43500296
a = [1, 2, 3]
print('a: {}, id: {}'.format(a, id(a))) # a: [1, 2, 3], id: 43499976
func(a)
print('a: {}, id: {}'.format(a, id(a))) # a: [1, 2, 3, 4], id: 43499976
new=['1','2','3']
lis=['asd','ass']
lis.append(new)
new.append('4')
print(lis)
print(new)
print(id(lis[2]))
print(id(new))
print(id(new[0]))
print()
a=['1','2','3']
b=['asd','ass']
b.append(a)
a.append('5')
print(b)
print(a)
print(id(b[2]))
print(id(a))
print(id(a[0]))
print()
c=['a',['b'],'c']
d=['fg','hj']
print(type(c+[5]))
print(id(c+[5]))
print(id(c+[5]))
print(id(c+[5]))
print(id(c+[5]))
e=c+[5]
print()
c[1].append('sd')
print(id(c))
print(id(e))
print(c)
print(e)
print(id(c))
print(id(e))
错了错了,id应该打在前面啊,233333333333
c=['a',['b'],'c']
print(id(c))
c=c+[5]
print(c)
print(id(c))
+++++++++++++++++++++++++++++++分割线++++++++++++++++++++++++++++++++++
好了,那个循环的问题也解决了
主要是因为写下 c+[5]这句话的时候,系统会把它分配到一个接着上一次的内存地址上
但是这个c+[5]之后并没有赋值给谁,所以这个临时的变量和所开的空间又消除了,(但是在下一次print(id(c+[5]))之前还没有消除,所以会出现当前c+[5],继续接着上一次的内存地址存放,这句话结束后,之前的c+[5]的内存空间认为这段内容没人用了,所以就自我消亡了,再再下一次print(id(c+[5]))时,再次分配这一段连续的内存,如此循环往复。
可以看到下面一段程序,在分配给d 的内存空间,恰好是上一次c+[5]的临时空间的地址,印证了我的说法。
c=['a','b','c']
print(c)
print(id(c))
print()
print(id(c+[5]))
d=['d','e']
print(id(d))
print(id(c+[5]))
print(id(c+[5]))
print(id(c+[5]))
print()
c=c+[5]
print(c)
print(id(c))