闭包与延迟绑定的个人强行理解

在这里插入代码片


def multipliers():
    funcs = []
    for i in range(4):
        def bar(x):
            return x*i
        funcs.append(bar)
    return funcs
print ([m(2) for m in multipliers()] 

我的理解是这样的


在multiplirers()函数内for循环遍历了4次,每次给funcs内添加了一个bar()函数的引用,等于放了4个bar,funcs=[bar,bar,bar,bar]然后后把funcs返回。此时,i并没有向bar()函数传入,因为bar()函数没有被调用,也就无法运行bar()
函数里的代码,只有运行bar()函数时,i才会被bar()函数运用。

看见return我想到的是返回给一个变量,所以我假设a=multiplirers(),返回的funcs是a,所以a也是一个列表,所以a=[bar,bar,bar,bar]。遍历multipliers()等于遍历a,所以m就是bar()的引用,所以m(2)就是调用bar()函数并传入参数2,列表里有4个m,也就是调用4次bar()函数,此时调用时,for循环早已完毕,i只能为3被bar()函数运用。

可能我理解有毛病,我叫强行解释。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值