函数传入list参数时
def f(x,li=[]):
for i in range(x):
li.append(i*i)
print(li)
期望结果:
f(4)
#运算结果:[0, 1, 4, 9]
f(5)
#运算结果:[0, 1, 4, 9, 16]
print(‘--------------------------------------’)
#运算结果
f(4)
#运算结果:[0, 1, 4, 9]
f(5)
#运算结果:[0, 1, 4, 9, 0, 1, 4, 9, 16]
当定义函数时,会保存函数中默认参数 list的值,也就是列表 li=[];
在每次调用的时候如果传递了新的列表,则使用传递的列表,没有传递,使用定义函数时保存的默认参数(li=[]);
上面两次调用中,都没有传递新的列表(使用默认列表 li=[] ),程序会调用定义函数时保存的默认参数((li=[]));
列表在append的时候会在 li=[] 原来的基础上append追加值,所以会产生以上结果.
通过打印列表的ID进行辨识
def f(x,li=[]):
print('id:',id(li))
for i in range(x):
li.append(i*i)
print(li)
f(4)
#id: 2154086435336
#结果:[0, 1, 4, 9]
f(5)
#id: 2154086435336
#结果:[0, 1, 4, 9, 0, 1, 4, 9, 16]
会发现ID值是相同的;
说明两次执行时使用的都是定义函数时的默认参数 li=[ ]
执行时往里面传新的列表
def f(x,li=[]):
for i in range(x):
li.append(i*i)
print(li)
f(4)
#结果:[0, 1, 4, 9]
f(5,[])
#结果:[0, 1, 4, 9, 16]
f(6)
#结果:[0, 1, 4, 9, 0, 1, 4, 9, 16, 25]
当传递空列表时,函数体当中会使用传递的空列表,没有传递时,使用函数默认值 li=[ ], 所以会产生以上结果。
优化方案
- 如果想要达到预期的结果,只需要在函数体里进行判断即可:
def f(x, li=[]):
if not li:
# 如果li不为空的话,就往下走(清空列表); 为空就不走
li = []
for i in range(x):
li.append(i * i)
print(li)
f(4)
#结果:[0, 1, 4, 9]
f(5)
#结果:[0, 1, 4, 9,16]
f(6)
#结果:[0, 1, 4, 9,16,25]