#Python3.2
例子:
- l = list('abc')
- a = l
- a.append('d')
- print(l)
- l.append('e')
- print(a)
- l = list('abcde')
- print(id(l))
- print(id(a))
可见,a = l 即将 a 作为 l 的引用,类似于 C 语言中 & ;如果重新生成一个 l ,即使内容一致,id 也已经变化了,由于引用计数的原因,a 这个变量名仍然能找到它所指代的对象,不会迷失;
Python标准库中有个 copy 模块,用于对象之间的拷贝,其中常用的两个函数:copy 和 deepcopy;
copy.copy() 是浅拷贝,只拷贝了父对象,不会拷贝父对象中的子对象;deepcopy 是深拷贝,可以认为是完全的复制过去了;
- l = ['a', 'b', 'c', [1, 2, 3]]
- import copy
- a = copy.copy(l)
- b = copy.deepcopy(l)
- a.append('e')
- b.append('f')
- print(a, b, l)
- a[3][2] = 'x'
- b[3][2] = 'y'
- print(a, b, l)
可见,浅拷贝后,父对象中的子对象,即上例中列表中的列表,还是被共享着的;
对于一个 list 对象
- l = ['a', 'b', 'c']
如果
- l = l.append(l)
会得出一个很有意思的结果:
- >>l
- >>['a', 'b', 'c', [...]]
如果:
- a = l[4]
- a == l
- a is l
结果都是 True;
对于上述的例子中的 l, len(l) 是 5;如果
- l = l.extend(l)
则不会出现这种效果