Python中关于++和—(自增和自减)的理解

前言

更多内容,请访问个人 我的博客python


首先要知道的是,Python 中是没有 ++-- 的。那么要实现自增和自减的话,可使用以下操做:bash

a = a + 1
或
a += 1
复制代码

缘由分析

咱们知道, python中的数字类型是不可变数据。也就是数字类型数据在 内存 中是不会发生改变,当变量值发生改变时,会新申请一块内存赋值为新值,而后将变量指向新的内存地址。 实验以下:性能

>>> a = 10
>>> id(a)
140530470127960
>>> a += 1
>>> id(a)
140530470129080
复制代码

能够看到当 a 的值发生改变时,a 指向的内存地址也发生了改变。而在C语言中,a 指向的内存地址并不会发生改变,而是改变内存的内容。spa

+= 是改变变量,至关于从新生成一个变量,把操做后的结果赋予这个新生成的变量。
++ 是改变了对象自己,而不是变量自己,即改变数据地址所指向的内存中的内容。code

既然 Python 中的数字类型是不可变的,那何来的“自增”这么一说呢?对象

另外:blog

int 理论上是每次赋值都建立一个新对象的。可是因为使用频繁,为了提高性能避免浪费,全部 python 有个 整数池,默认 [-5, 256] 的数字都属于这个整数池,这些每次赋值的时候,是取得池中的整数对象。可是其余的除外,以下:ip

>>> a = 5
>>> b = 5
>>> id(a)
140530470128360
>>> id(b)
140530470128360
>>> a is b
True

>>> c = 257
>>> d = 257
>>> id(c)
140530470136432
>>> id(d)
140530470136408
复制代码

但:内存

有时候在 Python 中看到存在 ++i 这种形式,这其实不是自增,只是简单的表示正负数的正号而已。正正得正,负负得正,因此 ++i--i 都是 iget

相关文章
相关标签/搜索