def make_adder(addend):
def adder(augend):
return augend + addend
return adder
make_adder函数里嵌套了一个内层函数adder,这个内层函数就是一个闭包,其实可以也不用管这个“闭包”的概念,先来看下这种模式解决些什么问题,“闭包”只是个名称罢了。
调用make_adder函数:p = make_adder(23),由于内层的函数adder里的逻辑用到了make_adder函数的入参,而这时这个入参addend绑定了值23,由于make_adder函数返回的是函数adder,所以这时的p其实就是内部的addend绑定了23的函数adder;同理可知,q = make_adder(44),这里的q就是内部addend绑定了44的函数adder,p和q这两个adder函数是不相同的,因为内部addend绑定的值不同,只是两个函数的模板相同罢了,这时我们执行p(100)得到结果是123,q(100)得到结果是144。这样做有什么用呢?其实可以这样看:我们可以把p = make_adder(23)和q = make_adder(44)看成是配置过程,23和44是配置信息,p(100)和q(100)根据不同的配置获得不同的结果,这样我们就可以解决开发中“根据配置信息不同获得不同结果”的问题.
lol,亲你是不是花了不止一分钟,呵呵O(∩_∩)O~
copy from : http://blog.csdn.net/wyabc1986/article/details/7399104?reload
时间: 2025-01-06 14:20:38