先来看一段python代码,如下:
代码示例:
>>> i =1 >>> ++i >>> print i 1 [python] view plaincopy >>> i =1 >>> ++i >>> print i 1
以上代码告诉我们,python居然不认识++。
python 不使用 ++ 的哲学逻辑:编译解析上的简洁与语言本身的简洁。
例子:
代码示例:
>>> b = 5 >>> a = 5 >>> id(a) 162334512 >>> id(b) 162334512 >>> a is b True [python] view plaincopy >>> 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 已经是新值的名称。
更多技术请关注。