我是靠谱客的博主 谦让白羊,最近开发中收集的这篇文章主要介绍关于python自增运算(千万不要用++i,不然程序崩掉),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

出处:http://blog.csdn.net/xyqzki/article/details/38414677

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


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


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


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

[python]  view plain copy
  1. >>> b = 5  
  2. >>> a = 5  
  3. >>> id(a)  
  4. 162334512  
  5. >>> id(b)  
  6. 162334512  
  7. >>> a is b  
  8. True  

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


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


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

最后

以上就是谦让白羊为你收集整理的关于python自增运算(千万不要用++i,不然程序崩掉)的全部内容,希望文章能够帮你解决关于python自增运算(千万不要用++i,不然程序崩掉)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(70)

评论列表共有 0 条评论

立即
投稿
返回
顶部