Erster Code:
# -*- coding:gb2312 -*-
a = [100]
def test(num):
num += num #第一段代码
print(num)
test(a)
print(a)
Ausführungsergebnis:
Zweiter Code:
# -*- coding:gb2312 -*-
a = [100]
def test(num):
num = num + num #这个地方改了一下
print(num)
test(a)
print(a)
Ausführungsergebnis:
Meine Frage:
num += num sollte nicht direkt mun = num+num sein. Warum sind die berechneten Ergebnisse unterschiedlich? Was ist los
你可以尝试进行这样的操作,
通过id()这个函数可以得到变量所分配的内存地址。通过实验发现使用了
+
的变量地址发生了变化,也就是你所说的num+=num与num=num+num不等价。但是,当做如下骚操作时候又会发现啪啪啪打脸
分配的地址似乎一直在改变。
原因在于,Python中的数据结构分为可变(mutable)和不可变(immutable)。
对于可变类型,=和+=有着明显的不同,如上面的list:
+表示连接操作,+=表示追加
对于不可变类型,=和+=就是一样的操作,如上面的tuple
可变类型与不可变类型的本质在于内存空间是否可变~
首先看出区别在于
可以看出分别调用的方法不同,分别是__add__,__iadd__
加法运算符会计算出新的object来赋值给num
增量赋值运算符修改原来的引用
参考这儿: https://stackoverflow.com/que...
Remember that arguments are passed by assignment in Python.
傳參數在python是用assignment 不是reference,所以你傳a過去函數時傳的是a的值,而不是a本身。若你要改動a本身就需要用return傳值回來
結果:
在python中,a=a+b是先创建一个新的对象并让变量a引用这个对象,a+=b是让a所引用的对象的值变成a+b的值