Python闭包和装饰器

(1)python的LEGB:

LEGB是指:按照L>E>G>B 的顺序优先级进行变量查找。

L:local函数内部作用域,是最底层的单个函数里面;

E:enclosing函数内部与内嵌函数之间,是有内部函数的函数里面;

G:global 全局作用域,是一个.py文件中;

B:build-in内置作用域,比如:tuple,list,元组。是所有.py文件中。

(2)闭包

闭包是指:一个函数中内嵌了另一个函数,这个内嵌的函数会使用外部函数的参数变量,作为判决内嵌函数的不同运行模式的参考。最后外部函数会返回它的内嵌函数,即返回了函数对象地址,而这个内嵌函数就是我们说的闭包。用下面这个例子来说明:

def set_passline(passline):
    def cmp(val):
        if val >= passerine:
           print(‘Pass‘)
       else:
           print(‘failed‘)
    return cmp

f_100 = set_passline(60)
f_100(89)
f_150 = set_passline(96)
f_150(89)

  set_passline返回的是内嵌函数cmp这个函数对象,不同的实参passline决定不同的cmp函数对象,这个内嵌函数cmp也就是闭包。

总之,闭包就是指引用外部函数的内嵌函数, 它的主要作用是:(1)封装;(2)代码复用

此外,闭包中引用的外部函数参数也可以是函数,此时作用是:将多个不同函数中相同的处理部分抽象出来,放入闭包进行封装,而闭包又传入函数对象,这样,闭包中运行完相同处理部分后,就可以运行不同函数的特定代码。例子如下:

def my_sum(*arg):
    print(‘my_sum‘)
    return sum(arg)

def my_average(*arg):
    print(‘my_average‘)
    return sum(arg) / len(arg)

def dec(func):
    # 闭包
    def in_dec(*arg):
        print(‘in_dec()=‘, arg)
        # 将相同的处理部门进行封装
        if len(arg) == 0:
            return 0
        for val in arg:
            if not isinstance(val, int):
                return 0
        # 处理完相同部门,返回不同函数的特定处理
        return func(*arg)
    return in_dec

my_sum = dec(my_sum)
print(my_sum(1, 2, 3, 4, 5, 6))
print(my_sum(1, 2, 3, 4, 5, ‘6‘))

my_average = dec(my_average)
print(my_average(1, 2, 3, 4, 5, 6))
print(my_average(1, 2, 3, 4, 5, ‘6‘))

运行结果为:

(3)装饰器

  装饰器实质上就是对闭包的使用,通过封装相同部分的代码或者一些装饰代码,从而进行代码重用(有点类似于设计模式中的"装饰模式")。通过python解释器的装饰器语法糖(@dec,dec是闭包的外部函数名字)来显示地使用闭包,将函数作为实参传入闭包,最后装饰器将闭包装饰过的函数返回给被装饰函数,即:bar = dec(bar)。使用例子如下:

def deco(func):
    print("this is deco")
    def in_deco(x,y):
        print(‘this is closure‘)
        func(x,y)
    return in_deco

@deco #装饰器的语法糖,会将其下面的函数当做函数对象实参func传入deco, 相当于调用了bar = dec(bar)
def bar(x,y):
    print("this is bar")
    print("%d+%d=%d" % (x,y,x+y))

bar(2,4)

运行结果如下:

原文地址:https://www.cnblogs.com/ladawn/p/8918558.html

时间: 2024-11-08 20:47:31

Python闭包和装饰器的相关文章

python闭包和装饰器(转)

一.python闭包 1.内嵌函数 >>> def func1(): ... print ('func1 running...') ... def func2(): ... print ('func2 running...') ... func2() ... >>> func1() func1 running... func2 running... 内部函数func2作用域都在外部函数func1作用域之内 如果试图在外部函数的外部调用内部函数将会报错 >>&

python闭包以及装饰器

闭包 简单理解 所谓闭包简单点说就是定义一个函数,这个函数里面还有一个函数,此时里面的函数和外面函数中的变量之间就产生了闭包关系. 代码理解 # 定义一个函数 def test(num): # 里面还有一个函数 def test_inner(num_inner): # 这个函数和外面函数的变量num之间就产生了闭包 print(num + num_inner) return test_inner fun = test(10) fun(10) fun(20) 以上代码执行的结果是:20和30 从执

python闭包及装饰器

一.闭包 1.闭包就是在函数内部定义函数并返回内部函数 2.闭包实现代码的封装和复用 3.实例如图所示,内部定义一个比较函数,给定边界值即做出不同的判断 . 二.装饰器 1.装饰器就是利用闭包的原理 [email protected]就是装饰器的语法糖 3.装饰器可以给函数添加功能 4.实例如图所示,给求和函数添加参数预处理的功能

python闭包、装饰器

内部函数 闭包: 闭包将内部函数自己的代码和作用域以及外部函数的作用结合起来. 闭包的词法变量不属于全局名字空间域或者局部的--而是属于其他的名字空间,带着流浪的作用域. 闭包对于安装计算,隐藏状态,以及在函数对象和作用域中随意的切换是很有用的. 闭包也是函数,但是他们能携带一些额外的作用域. 实例 装饰器 装饰器是在函数调用之上的修饰 这些修饰是当声明一个函数或者方法的时候,才会应用的额外调用 使用装饰器的情形有: --引用日志 --增加计时逻辑来检测性能 --给函数加入事物的能力 装饰器实例

python闭包与装饰器

闭包闭包:两个函数的嵌套,外部函数返回内部函数的引用,外部函数一定有参数def 外部函数(参数): def 内部函数(): pass return 内部函数 他跟函数之间的区别: 1.格式两个函数嵌套 2.闭包外部函数的参数可以在内存中保持装饰器装饰器是什么:闭包加@xxx装饰器的作用:在不改变原先的函数值跟调用的方式,添加额外的功能装饰器的代码: def set_fun(func): def call_fun(*args,**kwargs): return func(*args,**kwarg

python闭包和装饰器的理解

闭包: 两个函数的嵌套,外部函数返回内部函数的引?,外部函数?定有参数 def 外部函数(参数): def 内部函数(): pass return 内部函数 他跟函数之间的区别: 1.格式两个函数嵌套 2.闭包外部函数的参数可以在内存中保持 装饰器是什么:闭包加@xxx 装饰器的作?:在不改变原先的函数值跟调?的?式,添加额外的功能 装饰器的代码: def set_fun(func): def call_fun(*args,**kwargs): return func(*args,**kwarg

python 闭包与装饰器

1.闭包--返回子函数名 作用:使用子函数之外的父函数的变量 闭包就是你调用了一个函数a,这个函数a反悔了一个子函数名b,这个返回的函数b就叫做闭包 代码举例 def a(): test = 'aa' def b(): print(test) return 1 return b c = a() print(c) print(c()) 统计做一件事情所需要的时间 做一批事情都想统计时间,如何做  装饰器=闭包+函数式编程 import time def deco(func): def _deco(

闭包和装饰器使用案例

''' @Author: 冯浩 @Date: 2019-12-04 22:58:49 @LastEditors: 冯浩 @LastEditTime: 2019-12-05 00:03:25 @FilePath: \bob_develop\python\闭包和装饰器.py ''' def deco(str_): def func0(func): print('func0', str_) def func1(num): print('func1', num) return func(num) ret

21.python中的闭包和装饰器

python中的闭包从表现形式上定义(解释)为:如果在一个内部函数里,对在外部作用域(但不是在全局作用域)的变量进行引用,那么内部函数就被认为是闭包(closure). 以下说明主要针对 python2.7,其他版本可能存在差异. 也许直接看定义并不太能明白,下面我们先来看一下什么叫做内部函数: def wai_hanshu(canshu_1): def nei_hanshu(canshu_2): # 我在函数内部有定义了一个函数 return canshu_1*canshu_2 return