[转载] python 没有++运算符,深入研究后发现,这个事情原来不像仅仅是没有这个运算符那么简单

参考链接: Python | a += b并不总是a = a + b

刚开始学Python,当想要自增运算的时候很自然的 a++,结果发现编译器是不认识 ++ 的,于是去网上搜了一下,结果发现一篇老外的问答很精彩,涉及到了 Python 这个语言的设计原理 

 问题无外乎就是 python 没有自增运算符,自增操作是如何实现的 

 回答中有人介绍了关于自增操作,python 不使用 ++ 的哲学逻辑:编译解析上的简洁与语言本身的简洁,就不具体翻译了 

 后面还有老外回答并附带了一个例子非常的精彩,指出了 python 与 c 语言概念上的一些差异,语言描述的可能未必准确,直接上例子: 


>>> b = 5  

>>> a = 5  

>>> id(a)  

162334512  

>>> id(b)  

162334512  

>>> a is b  

True  


可以看出, python 中,变量是以内容为基准而不是像 c 中以变量名为基准,所以只要你的数字内容是5,不管你起什么名字,这个变量的 ID 是相同的,同时也就说明了 python 中一个变量可以以多个名称访问 


 这样的设计逻辑决定了 python 中数字类型的值是不可变的,因为如果如上例,a 和 b 都是 5,当你改变了 a 时,b 也会跟着变,这当然不是我们希望的 

 因此,正确的自增操作应该 a = a + 1 或者 a += 1,当此 a 自增后,通过 id() 观察可知,id 值变化了,即 a 已经是新值的名称

你可能感兴趣的:([转载] python 没有++运算符,深入研究后发现,这个事情原来不像仅仅是没有这个运算符那么简单)