python函数定义中参数列表里的参数是_python函数中把列表(list)当参数时的"入坑"与"出坑"...

在Python函数中,传递的参数如果默认有一个为 列表(list),那么就要注意了,此处有坑.

入坑

挖坑

def f(x,li=[]):for i inrange(x):

li.append(i*i)print(li)print('---1---')

f(4)print('---2---')

f(5)

预期结果

---1---[0, 1, 4, 9]

---2---[0, 1, 4, 9, 16]

执行结果

---1---[0,1, 4, 9]---2---[0,1, 4, 9, 0, 1, 4, 9, 16]

出坑

当定义函数时,会保存函数中默认参数 list的值,也就是列表 li=[];

在每次调用的时候如果传递了新的列表,则使用传递的列表,没有传递,使用定义函数时保存的默认参数(li=[]);

上面两次调用中,都没有传递新的列表(使用默认列表 li=[] ),程序会调用定义函数时保存的默认参数((li=[]));

列表在append的时候会在 li=[] 原来的基础上append追加值,所以会产生以上结果.

通过打印列表的ID进行辨识

打印列表 li=[] 的ID:

def f(x,li=[]):print(id(li)) # 添加打印idfor i inrange(x):

li.append(i*i)print(li)print('---1---')

f(4)print('---2---')

f(5)

结果:

---1---

140306123906248[0,1, 4, 9]---2---

140306123906248[0,1, 4, 9, 0, 1, 4, 9, 16]

会发现ID值是相同的;

说明两次执行时使用的都是定义函数时的默认参数 li=[ ]

执行时往里面传新的列表

打印列表 li=[] 的ID 和 传的新列表的ID:

def f(x,li=[]):print(id(li))for i inrange(x):

li.append(i*i)print(li)print('---1---')

f(4)print('---2---')

f(5,[])print('---3---')

f(6)

结果:

---1---

140017293614280[0,1, 4, 9]---2---

140017293614472[0,1, 4, 9, 16]---3---

140017293614280[0,1, 4, 9, 0, 1, 4, 9, 16, 25]

会发现执行传递空(新)列表的函数时打印的ID不一样,而没有传递的一样;

当传递空列表时,函数体当中会使用传递的空列表,没有传递时,使用函数默认值 li=[ ], 所以会产生以上结果.

优化

如果想要达到预期的结果,只需要在函数体里进行判断即可:

def f(x, li=[]):if notli:#如果li不为空的话,就往下走(清空列表); 为空就不走

li =[]for i inrange(x):

li.append(i*i)print(li)print('---1---')

f(4)print('---2---')

f(5)print('---3---')

f(6)

结果:

---1---[0,1, 4, 9]---2---[0,1, 4, 9, 16]---3---[0,1, 4, 9, 16, 25]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值