为了账号安全,请及时绑定邮箱和手机立即绑定

求教 2-9闭包疑问

#求解,每返回一次,输出一次,为什么不行? 

#还有为什么返回的是fs列表而不是f函数? 

def count():

    fs = []     

    for i in range(1, 4):        

        def f():

            return i*i

        fs.append(f)

   return fs 

f1 = count() 

print f1(), 

f2 = count() 

print f2(), 

f3 = count() 

print f3(),


正在回答

2 回答

第一个问题:因为每次返回不立即计算出结果,而在调用的时候才进行计算。

第二个问题:fs列表中存储的是若干函数,肯定是返回fs

0 回复 有任何疑惑可以回复我~
#1

Ares_JY 提问者

非常感谢!
2017-06-05 回复 有任何疑惑可以回复我~

理论差不多就是楼上的啦
每个人可能实现方法不一样哈
def g():
ls=[]
m=range(1,4)
k=[-1]
for i in m:
  def f():
   k[0]=k[0]+1
   return m[k[0]]*m[k[0]]
  ls.append(f)
return ls
a=g()
print a[0]()
print a[1]()
print a[2]()
结果
1
4
9

2 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
python进阶
  • 参与学习       255665    人
  • 解答问题       2949    个

学习函数式、模块和面向对象编程,掌握Python高级程序设计

进入课程

求教 2-9闭包疑问

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信