1、思考下面的代码运行出的结果是什么:
list = [0, 1, 2]
list[1] = list
print(list)
结果:[0,[…],2]
2、第1题中如何最终得出list = [0, [0, 1, 2], 2]这样的结果?
list[1] = [0,1,2]
3、经过以下步骤, a和b分别是多少? 为什么?
a = [0, [1, 2], 3]
b = a[:]
a[0] = 8
a[1][0]= 9
结果:[8,[9,2],3]
[0,[9,2],3]
python里一切都是指向,这样来理解会容易很多
[:]是浅拷贝,只拷贝最上面一层
4、如何保证第3题中最终b = [0, [1, 2], 3]
b = copy.deepcopy(a)
5、写出下面代码执行结果:
L = [1, 2]
M = L
L = L + [3, 4]
print(L)
print(M)
结果:[1,2,3,4] [1,2]
6、写出下面代码执行结果:
L = [1, 2]
M = L
L += [3, 4]
print(L)
print(M)
结果:[1,2,3,4] [1,2,3,4]
7、执行以下代码,解释运行结果:
def foo(a, b, c=[]):
c.append(a)
c.append(b)
print©
foo(1, 2)
foo(1, 2, [])
foo(3, 4)
结果:[1, 2]
[1, 2, [] ]
[1, 2, 3, 4]
本文深入探讨了Python中列表的使用与拷贝机制,包括列表修改后的引用行为、浅拷贝与深拷贝的区别,以及不同操作对列表的影响。通过具体代码示例,解析了变量赋值、列表更新、函数参数传递等场景下列表的变化规律。
176万+

被折叠的 条评论
为什么被折叠?



