本文研究的主要是Python中的默认参数的相关内容,具体如下。
熟悉C++语言的可以知道,C++语言中的默认参数是写在函数声明中的,为语法糖,与函数的调用无关,是在函数调用的时候由编译器补齐参数然后进行调用。
而Python中的默认参数与其有相当大的不一样,如下例中的代码执行结果会是什么呢?
1
2
3
4
5
6
7
|
def test_parameter(a, dfp = []):
dfp.append(a)
print (dfp)
test_parameter( 1 )
test_parameter( 2 )
test_parameter( 3 )
|
从结果中可以看到其结果如下,与我们期望完全不一致:
1
2
3
|
[ 1 ]
[ 1 , 2 ]
[ 1 , 2 , 3 ]
|
分析
为什么Python的默认参数是这样的表现,需要从Python的函数定义说起。Python中 def 实际上是可执行语句,执行 def 的时候会创建一个函数对象,而默认参数也会在执行 def 语句的时候计算出来并存在函数的_defaults_属性中。
1
2
3
4
5
6
7
8
|
def test_parameter(a, dfp = []):
dfp.append(a)
print ( id (dfp))
test_parameter( 1 )
test_parameter( 2 )
print (test_parameter.__defaults__)
print ( id (test_parameter.__defaults__[ 0 ]))
|
结果如下,可见调用函数时使用的默认参数和_defaults_中的对象为同一对象:
1
2
3
4
|
140109485401224
140109485401224
([ 1 , 2 ],)
140109485401224
|
使用
在明白上述原理后,可以知道以后在使用默认参数的时候需要注意,如果默认参数是可变对象则需要判断是否每次调用函数时是共享默认参数还是产生新对象。如果是新生成对象,常采用None作为默认参数占位,如果判断当前为None,则新建可变对象使用。
1
2
3
4
|
def test(a, dfp = None ):
if dfp is None :
dfp = []
pass #使用dfp
|
总结
以上就是本文关于Python中的默认参数实例分析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
原文链接:http://blog.csdn.net/spirit_djy/article/details/50663563