python 沒有++運算子,深入研究後發現,這個事情原來不像僅僅是沒有這個運算子那麼簡單
阿新 • • 發佈:2019-01-05
剛開始學 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 已經是新值的名稱