關於 python 的自增運算


剛開始學 python,當想要自增運算的時候很自然的 a++,結果發現編譯器是不認識 ++ 的,於是去網上搜了一下,結果發現一篇老外的問答很精彩,涉及到了 python 這個語言的設計原理

 問題無外乎就是 python 沒有自增運算符,自增操作是如何實現的

 回答中有人介紹了關於自增操作,python 不使用 ++ 的哲學邏輯:編譯解析上的簡潔與語言本身的簡潔,就不具體翻譯了

 后面還有老外回答並附帶了一個例子非常的精彩,指出了 python 與 c 語言概念上的一些差異,語言描述的可能未必准確,直接上例子:

 >>> b = 5  

  1. >>> a = 5  
  2. >>> id(a)  
  3. 162334512  
  4. >>> id(b)  
  5. 162334512  
  6. >>> a is b  
  7. True  

可以看出, python 中,變量是以內容為基准而不是像 c 中以變量名為基准,所以只要你的數字內容是5,不管你起什么名字,這個變量的 ID 是相同的,同時也就說明了 python 中一個變量可以以多個名稱訪問

 這樣的設計邏輯決定了 python 中數字類型的值是不可變的,因為如果如上例,a 和 b 都是 5,當你改變了 a 時,b 也會跟着變,這當然不是我們希望的

 因此,正確的自增操作應該 a = a + 1 或者 a += 1,當此 a 自增后,通過 id() 觀察可知,id 值變化了,即 a 已經是新值的名稱

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM