关于python的内存存储问题
>>> x =>>> def invert(x):
... x = x[::-1]
...
>>> invert(x)
>>> print(x)
>>> # 请问这里会打印什么内容?
--------------------------------------------------------------------------------------------------------
>>> x =
>>> def invert(x):
... x[:] = x[::-1]
...
>>> invert(x)
>>> print(x)
>>> # 请问这里会打印什么内容?
为什么这两个函数的打印结果不同,希望有大佬从python的内存角度解答一下。小甲鱼的课后答案解析是错误的,自己想了很久也想不明白 有点不理解为什么下面的函数换成x序列的切片之后结果就出现变化,上面的没有用切片直接用变量x接收就没有任何改变仍然输出 爱睡懒觉 发表于 2023-4-26 11:15
为什么这两个函数的打印结果不同,希望有大佬从python的内存角度解答一下。小甲鱼的课后答案解析是错误的, ...
这两个函数的打印结果不同,是因为它们在内存中的处理方式不同。让我从Python的内存角度为您解释这个问题。
在第一个示例中:
1. 我们创建了一个名为x的列表 ``,并为其分配了内存。
2. 在`invert`函数中,我们使用切片操作`x[::-1]`创建了一个新的列表,它是x的逆序副本。此时,新列表与原始列表x在内存中是分开的。
3. 在函数内部,我们将变量x重新赋值为新列表。但是,这并没有影响到原始列表x,因为重新赋值的操作仅仅是改变了函数内部的x引用,指向了新创建的逆序副本。
4. 函数执行结束后,我们打印原始列表x,它的内容并没有改变,所以输出是``。
在第二个示例中:
1. 同样,我们创建了一个名为x的列表 ``,并为其分配了内存。
2. 在`invert`函数中,我们使用切片操作`x[::-1]`创建了一个新的列表,它是x的逆序副本。
3. 与第一个示例不同的是,我们使用`x[:]`这种形式的切片赋值,直接修改了原始列表x的内容。`x[:]`表示整个列表,这样赋值操作会将原始列表x的内容替换为新列表的内容,而不是创建新的引用。因此,原始列表x现在在内存中存储的内容已经变成了逆序列表。
4. 函数执行结束后,我们打印原始列表x,它的内容已经改变,所以输出是``。
总之,在第一个示例中,我们创建了一个新的逆序列表,并在函数内部将其赋值给变量x,但这并没有影响到原始列表x。而在第二个示例中,我们直接修改了原始列表x的内容,使其变为逆序。因此,这两个示例的打印结果不同。 x=x[::-1]
这行代码由于没有指定x是全局变量,所以定义的这个x是函数内的局部变量,没有影响到全局变量x
但
x[:]=x[::-1]
由于x[:]的值必须要定义x后才能更改,但函数中又没有定义x,所以将全局变量x进行了赋值。
页:
[1]