增量赋值运算符 += 和 *= 的表现取决于它们的第一个操作对象
-
+= 操作首先会尝试调用对象的 __ iadd__方法,如果没有该方法,那么尝试调用__add__方法,所以+= 与 + 的区别实质是__iadd__ 与 __add__的区别,同理,
-
*= 操作首先会尝试调用对象的__imul__方法,如果没有该方法,那么尝试调用__mul__方法。
_ add_ 和 _ iadd_ 的区别
- _ add_ 方法接收两个参数,返回它们的和,两个参数的值均不会改变。
- _ iadd_ 方法同样接收两个参数,但它是属于 in-place 操作,就是说它会改变第一个参数的值,因为这需要对象是可变的,所以对于不可变对象没有__iadd__方法。
hasattr(int,'__iadd__') // False
hasattr(list,'__iadd__) // True
显然,整数对象是没有__ iadd__的,而列表对象提供了__iadd__方法。
不可变类型对象 数字
a = 123
id(a)
>>> 1688042320
a += 123
id(a)
>>> 246
>>> 1688046256
a *= 2
id(a)
>>> 492
>>> 1688052012
可变类型对象的列表
L = [1,2,3]
id(L)
>>> 4311953800
L *= 2
>>> [1,2,3,1,2,3]
id(L)
>>> 4311953800
___________________________
t = (1,2,3)
id(t)
>>> 4312681568
t *= 2
id(t)
>>> 4301348296
L1 = range(3)
L2 = L1
L1 = L1 + [3]
PS:遇到问题没人解答?需要Python学习资料?可以加点击下方链接自行获取
note.youdao.com/noteshare?id=2dce86d0c2588ae7c0a88bee34324d76
+操作调用的是 _ add_ 方法,该方法会返回一个新的对象,原来的对象保持不变,l1还是指向原来的对象,而l2已经指向一个新的对象。
L1 = range(3)
L2 = L1
L1 += [3]
+= 操作调用的是__iadd__方法,他会原地修改l2指向的那个对象本身的值
一道关于 += 的谜题
t = (1,2,[3,4],7)
t[2].append(5)
>>> (1,2,[3,4,5],7)
t[2] += [6]
>>> Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'tuple' object does not support item assignment
t
>>> (1,2,[3,4,5,6],7)