在Python函数中,传递的参数如果默认有一个为 列表(list),那么就要注意了,此处有坑.
入坑
挖坑
![1153adc07dab013f7caf979e03dd99bb.png](https://i-blog.csdnimg.cn/blog_migrate/171ef89cd852408d014147468d84ced3.png)
预期结果
![3bee60cbab39ada8a3344496a7cb229b.png](https://i-blog.csdnimg.cn/blog_migrate/efce957711d03daf689c296a496fcfae.png)
执行结果
![295204608de6cbe65a774104d4585036.png](https://i-blog.csdnimg.cn/blog_migrate/7c2cf7ba94b8f82f6cfa4d8f92ff1878.png)
出坑
当定义函数时,会保存函数中默认参数 list 的值,也就是列表 li=[];
在每次调用的时候如果传递了新的列表,则使用传递的列表,没有传递,使用定义函数时保存的默认参数(li=[]);
上面两次调用中,都没有传递新的列表(使用默认列表 li=[] ),程序会调用定义函数时保存的默认参数((li=[]));
列表在append的时候会在 li=[] 原来的基础上append追加值,所以会产生以上结果.
通过打印列表的ID进行辨识
打印列表 li=[] 的ID:
![2e96994ffa0c7cb25b2ef3c700892b83.png](https://i-blog.csdnimg.cn/blog_migrate/29eecde801e7eb849aebc051db5ac399.png)
结果:
![48ed6273ec334cfb3e2a1248a2883fc3.png](https://i-blog.csdnimg.cn/blog_migrate/127ddd6abebc1a398709e59eaeace74e.png)
会发现ID值是相同的;
说明两次执行时使用的都是定义函数时的默认参数 li=[ ]
执行时往里面传新的列表
打印列表 li=[] 的ID 和 传的新列表的ID:
![487cef313af9bd44e76306d4a5743f7c.png](https://i-blog.csdnimg.cn/blog_migrate/9eaf58234643f56a455abb48abb954ad.png)
结果:
![62318261d58bac8b84e4fd65f808cc58.png](https://i-blog.csdnimg.cn/blog_migrate/cf975351ce45d5713d09e32608a4e71b.png)
会发现执行传递空(新)列表的函数时打印的ID不一样,而没有传递的一样;
当传递空列表时,函数体当中会使用传递的空列表,没有传递时,使用函数默认值 li=[ ], 所以会产生以上结果.
优化
如果想要达到预期的结果,只需要在函数体里进行判断即可:
![4f61810c39a9c69ccafd6999d623305d.png](https://i-blog.csdnimg.cn/blog_migrate/5c754d3bfe92a90b03d9c3dc68e032d9.png)
结果:
![b34c6b82dbd4294b9dcfc9eee8e42e9a.png](https://i-blog.csdnimg.cn/blog_migrate/ecdc94e1126deeec2927944db8cd4292.png)
转自:python函数中把列表(list)当参数时的"入坑"与"出坑"