python3 基础教程: 闭包实例解析

一、实例1:

def make_power(y):
    def fn(x):
        return x**y
    return fn

pow3 = make_power(3)
pow2 = make_power(2)
pow100 = make_power(100)

print('3的3次方=',pow3(3),"\t")
print('3的2次方为:',pow2(3),"\t")
print('3的100次方为:',pow100(3),"\t")

二、实例2(面试题):

下面这段代码的输出结果是什么?请解释:
代码:

'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
def multipliers():
    return [lambda x: i * x for i in range(4)]
print([m(2) for m in multipliers()])
#输出结果:[6,6,6,6]
#(不是我们想要的[0,2,4,6])

原因:

上述问题产生的原因是Python闭包的延迟绑定。这意味着内部函数被调用时,参数的值在闭包内进行查找。

因此,当任何由multipliers()返回的函数被调用时,i的值将在附近的范围进行查找。那时,不管返回的函数是否被调用,for循环已经完成,i被赋予了最终的值3。

解决办法:

方法1:python生成器

def multipliers():
    for i in range(4):yield lambda x:x*i

print([m(2) for m in multipliers()])  #[0,2,4,6]

方法2:

def multipliers():
    return [lambda x,i = i :i*x for i in range(4)]

print([m(2) for m in multipliers()])  #[0,2,4,6]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值