#为什么print(make_list()(20))和print(make_list()(30))是调用了两次make_list()函数,averagae=make_list(),这个用赋值产数调用函数,是由于只调用了一次make_list函数嘛?所以列表可以叠加?
def make_list():
new=[]
def average(a):
new.append(a)
print(new)
return sum(new)/len(new)
return average
average=make_list()
print(make_list()(20))
print(make_list()(30))#调用两次make_list函数,每次调用都在重新分配内存空间
print
print(id(average))
print(average(20))
print(average(30))#average是make_list()对象赋值,即只掉用一次make_list函数
你的注释 理解是对的,但实际的执行结果略有出入,尽管执行结果无差异。主要在‘new’的定义上。
# python3代码
def make_list():
new = list()
# new = [] # print(make_list()(60)) 多次调用返回的id 相同
print(id(new))
def average(a):
new.append(a)
print(new)
return sum(new)/len(new)
return average
print(make_list()(60)) # 每次 调用外层函数make_list,都会 新建列表‘new’,
print(make_list()(70)) # 然后执行内部average,操作的都是空的'new'。添加,打印,计算
ml1 = make_list()
ml2 = make_list()
print(ml1(20)) # 每次 调用外层函数make_list,都会 新建列表‘new’,
print(ml1(30)) # 然后执行内部average,操作的都是空的'new'。添加,打印,计算
print()
average = make_list() # 仅调用一次外层函数,初始化一个列表 'new',返回闭包
print(id(average), average(20)) # 调用闭包,使用已有的'new'
print(id(average), average(30)) # 调用闭包,使用已有的'new'