我们知道Python函数的默认参数值在定义函数时已经生成,如果是可变对象的话,自始至终都是同一个对象,所以对其的修改会保存,下一次调用的默认参数就是修改后的,而不是参数列表中看到的那个了。参考:Python函数的默认参数值在定义函数时已经生成
这本是一个坑,但是如果善加利用可以非常方便。
今天遇到一个需求:避免每次类初始化时都调用外部方法重复创建对象,希望最多创建一次,之后就用这一个对象。大概是下面这样:
WORD = 123
class Test():
def __init__(self, Trans):
self.wd = Trans(WORD)
Trans是外部方法,需要Test类被初始化的时候传入。(如果不是这样我本来可以在类外创建全局变量TRANS_WORD=Trans(WORD),self.wd=TRANS_WORD就可以实现只创建一次了)
创建Trans(WORD)比较耗时,所以希望创建一次之后一直用这个 。用闭包当然是一种方法,但是相对繁琐,所以想到利用默认参数的方法:
WORD = 123
class Test():
def __init__(self, Trans, trans_list=[]):
if not trans_list:
trans_list.append(Trans(WORD))#注意这里一定要是原位修改,+=、extend也行,=是不行的
self.wd = trans_list[0]
之后再多次创建这个类,trans_list可以不传,就只有第一次会调用Trans(WORD),之后用的都是第一次创建的同一个Trans(WORD)。