python 函数变量作用域和变量类型解说

不可变类型:

#-*- coding=utf-8 -*-

a = 100

def test(num):
    # 如果是不可变类型,函数不会修改原始的值.如果是可变类型.函数默认是引用传递.会修改以前的值
    # num +=num
    print(num)

test(a)
print(a)

代码效果

file

解读:

变量a是整型属于不可变类型,所以传递到test函数里.num属于不可变类型,函数里num最终的值就会为
200, 打印的print(a) 的值就会为100.

命令行效果

python3 函数引用变量使用的注意点.py

file

可变类型:

#-*- coding=utf-8 -*-

b = [100]

def test(num):
    # 如果是不可变类型,函数不会修改原始的值.如果是可变类型.函数默认是引用传递.会修改以前的值
    num +=num
    # num = num+num
    print(num)

test(b)
print(b)

代码效果

file

解读:

变量b是列表属于可变类型,所以传递到test函数里.num就默认引用传递了,而变量b又属于全局变量,函数里num最终的值就会为[100, 100], 打印的print(b) 的值也会为[100, 100].

命令行效果

python3 函数引用变量使用的注意点.py

file

注意

这里唠叨一句, num+=numnum=num+num结果不是一样的.

num +=num** 解说

#-*- coding=utf-8 -*-

b= [100] #定义一个可变类型列表变量b

def test(num):
    num +=num 
    print(num)

test(b)
print(b)

file

file

这里的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)

file
file

这里的num指向的内存空间还是以前变量b开辟的空间,而num = num+num , 根据python运算符优先级顺序首先会算num+num就等于 [100,100] 然后就是赋值运算了这时会重新开辟一个新的空间存储[100,100]. 所以.函数里的num的结果不会影响函数外的变量b了.

猜你喜欢

转载自blog.csdn.net/cpongo6/article/details/89249313