在编程语言中,函数的参数传递有两种状况:python
num = 10
def double(arg):
arg=arg*2
print(arg)
double(num)
复制代码
调用该函数,传入一个变量,其实传入的是该变量的一个副本,该变量在函数中发生变化,不影响函数外面该变量。编程
def change(arg):
arg.append('More data')
print(arg)
saying = [42,34,55]
change(saying)
复制代码
调用该函数,传入一个变量,可是函数内部倒是维护该变量的一个指向连接,连接到函数外面的这个变量;当传入函数的这个变量在函数内部发生改变,直接影响到外面的最初变量,由于有指向关系。bash
python
中的函数参数既支持按值调用,也支持按引用调用。app
python中的变量是对象引用
:变量存储的值是内存地址。当函数被调用的时候,解释器会查看传入的变量(内存地址)指的那个指的类型,若是是一个可变类型
的值,就按照引用传递变量;若是是一个非可变类型
的值,就考虑按照值传递变量。编程语言
可变类型
:字典dict
,列表list
,集合set
:函数
传入函数中的变量,函数内部的修改都会反映到函数外面,即最初始的变量会受到影响,毕竟这些初始的变量是可变类型。ui
不可变类型
:字符串srt
,整数int
,元组trulp
:spa
在这中,函数对变量的任何修改都是函数私有的,不会反映到函数外面,因为这些变量是不可变的,因此不能修改。3d
例外:code
def double(arg):
print('before: ',arg)
arg = arg * 2
print('After: ',arg)
复制代码
根据上面所说的,为何这个函数里面的参数,传入的一个可变类型,函数内部发生了改变,结果却没有反映到函数外面呢?
咱们考虑到这条语句:arg = arg*2
首先,传入的变量,先执行arg*2
,所产生的新的变量(新对象的引用),从新赋值给原先的变量arg
,覆盖其原先的引用,致使原先的变量arg
与外面初始变量之间的联系断了。既然关系断了,那么函数里面的arg
的改变,没有反映出来,因此并无影响到函数外面的变量。