022天津交友网,今天的五年二班ova,暧昧特工
一开始学习 python 的时候习惯性的使用 c 中的 a++ 这种写法,发现会报 syntaxerror: invalid syntax 错误,为什么 python 没有自增运算符的这种写法呢?
我们可以看一下 python 下:
>>>a = 2 >>>b = 2 >>>id(a) #id() 函数用于获取对象的内存地址。 140732976575344 >>>id(b) 140732976575344 >>>
再来看看 c 语言中:
#include<stdio.h> int main() { int a = 1; int b = 1; printf("%d\n",&a); printf("%d\n",&b); return 0; }
输出:
这里可以看出 python 在变量的存储上与 c 语言的不同,在 c 语言中,值的存储以变量名来区分,一个变量具有单独的地址空间;而 python 中则不一样,只要值是相同的,不管你的变量名是什么,它们的地址都是相同的,也就是说, python 允许一个值被多个变量名称绑定。
这里说明一下,在脚本式编程环境中是这样,但是在交互式编程环境下,python 为了优化速度,使用了小整数对象池, 避免为整数频繁申请和销毁内存空间,编译器会有一个小整数池的概念,小整数的定义是 [-5, 256] 这些整数对象是提前建立好的,不会被垃圾回收,也就是说,变量在这个范围内是会按照前面所说的,共用内存地址,超过这个值则使用单独的内存地址。 如:
>>>a=1000 >>>b=1000 >>>id(a);id(b) 266662366224 266617350384 >>>
总结
以上所述是小编给大家介绍的为什么python中没有"a++"这种写法,希望对大家有所帮助
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
python求numpy中array按列非零元素的平均值案例
网友评论