|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
x = [1,2,3]
y =x
x = x[::-1]
print(x,y)
z = [1,2,3]
m =z
z[:] = z[::-1]
print(z,m)
输出结果:
[3, 2, 1] [1, 2, 3]
[3, 2, 1] [3, 2, 1]
疑问:为什么加了一个冒号就会连着一起改变
在作业的答案中老师说第一种是x,y是分开存储的,第二种z,m是同一个对象的不同命名。不太理解。因为在代码前两行不是已经确定了存储方式吗,在我的理解下第三行只是对其修改吧,为什么会影响到存储方式呢
感谢!
在这两个例子中,存在两种不同的赋值方式,它们对变量之间的关系产生了不同的影响。
在第一个例子中:
- x = [1,2,3]
- y = x
- x = x[::-1]
复制代码
当我们执行 y = x 时,y 变量引用了与 x 相同的列表对象。但是,当我们执行 x = x[::-1] 时,我们创建了一个新的列表对象(一个反向的列表),并让 x 引用这个新的对象。此时,x 和 y 引用的是两个不同的对象,因此它们的值不会同时发生变化。
在第二个例子中:
- z = [1,2,3]
- m = z
- z[:] = z[::-1]
复制代码
当我们执行 m = z 时,m 变量引用了与 z 相同的列表对象。然后,当我们执行 z[:] = z[::-1] 时,我们使用切片操作 z[:] 直接修改了原始列表对象(不创建新对象)。因此,在这种情况下,z 和 m 仍然引用同一个对象,这个对象的内容已经被修改。这就是为什么在这个例子中,z 和 m 的值会同时发生变化。
总结一下,第一个例子中,x 和 y 分开存储是因为在执行 x = x[::-1] 时,创建了一个新的列表对象。而在第二个例子中,z 和 m 是同一个对象的不同命名,因为执行 z[:] = z[::-1] 时,直接修改了原始列表对象。切片操作 z[:] 是关键,它决定了是否创建新的列表对象还是直接修改原始列表对象。
|
|