Python中“i+=i与i=i+i”的区别梳理:(引用、内存、可变参数、不可变参数)

Python中“i+=i与i=i+i”的区别梳理

一、 "i+=i"执行时数据内存的变化

num+=num执行时,num原引用的内存空间中,根据空间中保存的参数的数据类型是否为可变类型而进行变化,***可变的参数数据类型***有:列表、字典;***不可变参数的类型***有:数字、字符串、元组。

#代码1
a=100
def test(num):
    num+=num
    print("in----test----  num="+str(num))

test(a)
print(a)

当a=100时,100为不可变类型,因此当函数中的num指向100并需要发生改变时,
num中的100无法直接改变,因此函数test中的第一个num实质上是一个局部变量,
每一次都指向一个新的“和值”对应的内存空间,因此输出结果为num:200,a:100,
全局变量a的值未发生变化。

#代码2
a=[100]
def test(num):
    num+=num
    print("in----test----  num="+str(num))

test(a)
print(a)

当a=[100]时,a指向一个类型为可变类型的内存空间,因此当sum+=sum执行时,
该内存空间中的值发生了变化,列表内容进行了合并,a的引用不发生改变,
输出结果为num:[100,100],a:[100,100],可以看出全局变量a的值也发生了变化。

因此在使用函数对全局变量进行计算时,应当注意全局变量是否为可变类型。

二、"i=i+i"执行时数据内存的变化

num=num+num执行时,num指向一个记录了原内存空间中的数值通过表达式计算所得的结果新的内存空间。

#代码3
a=[100]
def test(num):
    num=num+num
    print("in----test----  num="+str(num))

test(a)  #[100,100]
print(a) #[100]

因此在函数运行结束后,即便全局变量为可变参数的类型,全局变量a所引用的内存空间中的值并没有发生改变。

发布了8 篇原创文章 · 获赞 16 · 访问量 4万+

猜你喜欢

转载自blog.csdn.net/knkn123/article/details/82973187
I