def line_conf(a, b):
def line(x):
return a*x + b
return line
line1 = line_conf(1, 1)
line2 = line_conf(4, 5)
print(line1(5), line2(5))
这个例子中,函数line与环境变量a,b构成闭包。
在创建闭包的时候,我们通过line_conf的参数a,b说明了这两个环境变量的取值,
这样,我们就确定了函数的最终形式(y = x + 1和y = 4x + 5)。
我们只需要变换参数a,b,就可以获得不同的直线表达函数。
由此,我们可以看到,闭包也具有提高代码可复用性的作用。
如果没有闭包,我们需要每次创建直线函数的时候同时说明a,b,x。
这样,我们就需要更多的参数传递,也减少了代码的可移植性。
利用闭包,我们实际上创建了泛函。line函数定义一种广泛意义的函数。
这个函数的一些方面已经确定(必须是直线),但另一些方面(比如a和b参数待定)。
随后,我们根据line_conf传递来的参数,通过闭包的形式,将最终函数确定下来。
LEGB原则
Local 本地函数内部 通过任何方式复制的,而且没有被global关键字声明为
全局变量的
Enclosing 直接外围空间 的本地作用域(如果多层嵌套,由内而外,直到最外层)
Global 全局空间,整个模块内
Builtin 内置模块
在上述四层任意一层找到符合要求的变量,不再向外查找,如果到最外还没找到,报错
def test():
x=10
def add(b):
x=x+2
return x+b
return add
上述程序报错,在函数add中,x未定义就使用。1.可将外部x改为列表x[0](python2中)
2.用nolocal限制x(python3中)
def line(x):
return a*x + b
return line
line1 = line_conf(1, 1)
line2 = line_conf(4, 5)
print(line1(5), line2(5))
这个例子中,函数line与环境变量a,b构成闭包。
在创建闭包的时候,我们通过line_conf的参数a,b说明了这两个环境变量的取值,
这样,我们就确定了函数的最终形式(y = x + 1和y = 4x + 5)。
我们只需要变换参数a,b,就可以获得不同的直线表达函数。
由此,我们可以看到,闭包也具有提高代码可复用性的作用。
如果没有闭包,我们需要每次创建直线函数的时候同时说明a,b,x。
这样,我们就需要更多的参数传递,也减少了代码的可移植性。
利用闭包,我们实际上创建了泛函。line函数定义一种广泛意义的函数。
这个函数的一些方面已经确定(必须是直线),但另一些方面(比如a和b参数待定)。
随后,我们根据line_conf传递来的参数,通过闭包的形式,将最终函数确定下来。
LEGB原则
Local 本地函数内部 通过任何方式复制的,而且没有被global关键字声明为
全局变量的
Enclosing 直接外围空间 的本地作用域(如果多层嵌套,由内而外,直到最外层)
Global 全局空间,整个模块内
Builtin 内置模块
在上述四层任意一层找到符合要求的变量,不再向外查找,如果到最外还没找到,报错
def test():
x=10
def add(b):
x=x+2
return x+b
return add
上述程序报错,在函数add中,x未定义就使用。1.可将外部x改为列表x[0](python2中)
2.用nolocal限制x(python3中)