先看代码
# Arg 只是接口,实际使用中用到的是 Arg 的各种实现的实例,但实在没有的话会把 Arg 实例化作为参数
class Arg:
def method_a(self):
pass
def method_b(self):
pass
# 我个人习惯是签名处实例化
# 在签名处初始化例子
class MyDummy:
def __init__(self,arg=Arg()):
self.arg = arg
# 我看到项目总其他的代码如下
# 默认为 None,在函数执行时候再初始化
class OtherDummy:
def __init__(self,arg=None):
if arg == None:
self.arg = Arg()
# 一般使用下,大家都没问题
my_dummy = MyDummy()
other_dummy = OtherDummy()
# MyDummy 会出问题的情况
my_dummy = MyDummy(arg = None)
other_dummy = OtherDummy(arg = None)
# 我是想不出为什么要用第二种写法?难道是 PEP 推荐?
想问一下,大家看法和建议?
1
Vegetable 2020-07-31 11:19:34 +08:00
*不要用可变对象作为函数的默认参数
|
2
Vegetable 2020-07-31 11:23:56 +08:00 1
|
3
xiaolinjia 2020-07-31 11:30:02 +08:00 1
编译完之后,Arg 便实例化了一次,且待在内存里不动。当 MyDummy 实例化且不传参时,多个 MyDummy 实例的 arg 都指向同一个 Arg 实例
a = MyDummy() b = MyDummy() 对 a.arg 干点啥会影响到 b.arg 。你应该不会想这样吧? |
4
BingoXuan OP @xiaolinjia
实际运用中,Arg 是有且只有唯一的单例,实例化后资源是唯一的 |
5
BingoXuan OP @xiaolinjia
@Vegetable 虽然记得默认参数不要用 mutable,但我都忘了 object 本身就是 mutable 的。自己的锅。最近 golang 写多了,习惯都写个 New 函数。 |