思考分析Python运算中 a+=b 和 a=a+b是否相等
如题,先上代码
a+=b
>>> b = </code><code>[</code><code>0, 1, 2</code><code>]</code>
<code>>>> a = b
>>> a += [3]
>>> b
[0, 1, 2, 3]
>>> a
[0, 1, 2, 3]
此时a和b的结果是一样的
再看
a=a+b
>>> b = [0, 1, 2]
>>> a = b
>>> a = a + [3]
>>> b
[0, 1, 2]
>>> a
[0, 1, 2, 3]
a不等于b
显然,两者是有区别的,而且这种区别只出现在可变对象(为什么是可变对象后面再说),是什么原因造成了两者的区别呢?
+= 操作调用的是 __iadd__方法,如果对象没有该方法时,再尝试去调用__add__方法
a = [0, 1, 2]
a += [3]
# 等价于
a=a.__iadd__([3])
print(a) #[0, 1, 2, 3]
__iadd__方法直接在原对象a上进行更新,对于list来说,iadd返回self,最后是需要做一次看上去多余的赋值,因为python编译器在编译的时候并不知道a是什么类型,统一编译成这样兼容可变和不可变类型。
+ 操作调用__add__方法
a = [0, 1, 2]
a += [3]
# 等价于
a=a.__iadd__([3])
print(a) #[0, 1, 2, 3]
__add__方法会返回一个新的对象,原对象不修改,因为这里 a被重新赋值了,a指向了一个新的对象,而b还是指向原来对象,所以出现了文章开头a不等于b的情况
a = [0, 1, 2]
print(a.__add__([3])) # [0, 1, 2, 3]
print(a) # [0, 1, 2]
为什么前面我说这种差异只会发生的可变对象身上?因为对于不可变对象,根本没有 __iadd__方法,所以+=和+的效果是一样的,调的都是 __add__ 方法。
内置对象中,常见的不可变对象和可变对象有哪些呢?这种事情ChatGPT很擅长回答。
ChatGPT除了给你列出表格,还会给你解释什么是可变对象和不可变对象
可变对象是指创建后可以被修改的对象,例如列表、字典和集合等,这些对象可以增加、删除、修改其中的元素。而不可变对象则是创建后不能被修改的对象,例如数字、字符串、元组和布尔值等,这些对象在创建后不能被修改。
需要注意的是,Python 中的一些不可变对象,例如元组和命名元组,可以包含可变对象,例如列表和字典。这意味着虽然元组本身是不可变的,但是元组中包含的可变对象可以被修改。此外,Python 中还有一些特殊的对象,例如 frozenset,它是一种不可变的集合,不能被修改。
ChaGPT绝对算是一个不折不扣的辅助编程神器
ai不会让你失业,会用AI的人才会让你失业,ChatGPT不会淘汰你,能先驾驭ChatGPT的人会淘汰你。
以上就是Python运算中 a+=b 和 a=a+b是否一样原理的思考分析详细内容,更多关于Python 运算的资料请关注其它相关文章!
相关文章