不可变类型:
#-*- coding=utf-8 -*-
a = 100
def test(num):
# 如果是不可变类型,函数不会修改原始的值.如果是可变类型.函数默认是引用传递.会修改以前的值
# num +=num
print(num)
test(a)
print(a)
代码效果
解读:
变量a
是整型属于不可变类型,所以传递到test函数里.num
属于不可变类型,函数里num
最终的值就会为
200, 打印的print(a)
的值就会为100.
命令行效果
python3 函数引用变量使用的注意点.py
可变类型:
#-*- coding=utf-8 -*-
b = [100]
def test(num):
# 如果是不可变类型,函数不会修改原始的值.如果是可变类型.函数默认是引用传递.会修改以前的值
num +=num
# num = num+num
print(num)
test(b)
print(b)
代码效果
解读:
变量b是列表属于可变类型,所以传递到test函数里.num就默认引用传递了,而变量b又属于全局变量,函数里num最终的值就会为[100, 100], 打印的print(b) 的值也会为[100, 100].
命令行效果
python3 函数引用变量使用的注意点.py
注意
这里唠叨一句, num+=num和num=num+num结果不是一样的.
num +=num** 解说
#-*- coding=utf-8 -*-
b= [100] #定义一个可变类型列表变量b
def test(num):
num +=num
print(num)
test(b)
print(b)
这里的num指向的内存空间还是以前变量b开辟的空间,所以num = [100,100] ,所以变量b也跟着变成了[100,100],因为他们是引用传值关系.
num=num + num解说
#-*- coding=utf-8 -*-
b= [100] #定义一个可变类型列表变量b
def test(num):
num = num+num
print(num)
test(b)
print(b)
这里的num指向的内存空间还是以前变量b开辟的空间,而num = num+num , 根据python运算符优先级顺序首先会算num+num就等于 [100,100] 然后就是赋值运算了这时会重新开辟一个新的空间存储[100,100]. 所以.函数里的num的结果不会影响函数外的变量b了.