python3装饰器的简单解释

#闭包,也叫词法闭包:如下所示函数A主要是为了函数B提供运行环境的
#闭包只是在表现和形式上像函数,其实闭包并不是函数
#由函数在嵌套环境中,内层函数里,对外层函数作用域的变量进行了引用,那么在外层函数返回后,内层函数依然可是使用外层函数的变量,这样的变量就构成了可以使用时的环境
#所以闭包对于隐藏状态,以及在函数和作用域中进行切换,一个函数可以发挥很多种功能
#

#闭包:如下所示我们只需要不断的变化f调用变化就可以是函数B跟着变化了
def A(num1,num2):
    def B(x,y):
        print("我是%s!"%(num1+x))
        print("我是%s!"%(num2+y))
    return B
f=A(1,2)
f(3,4)

装饰器:

一下面的例子为例,如果我们有一个简单的函数C,我们在不动其他函数的基础上需要给函数C增加新的功能,需要怎么做呢?这就需要用到装饰器了

#这是不用装饰器时:
def A(func):
    def B():
        print("我是附加功能1!") #附加功能
        func()
        print("我是附加功能2!")  # 附加功能
    return B

def C():
    print("我是函数原来的功能!")
res=A(C)
res()
#用装饰器时:
def A(func):
    def B():
        print("我是附加功能1!") #附加功能
        func()
        print("我是附加功能2!") #附加功能
    return B
@A
def C():
    print("我是函数原来的功能!")
C()
#带参数的装饰器:
def A(func):
    def B(x):
        print("我是附加功能1!") #附加功能
        func(x)
        print("我是附加功能2!") #附加功能
    return B
@A
def C(x):
    print("我是函数原来的功能!%s"%x)
C('hello action!')

原文地址:http://blog.51cto.com/853056088/2131108

时间: 2024-11-07 03:10:29

python3装饰器的简单解释的相关文章

python3 装饰器

看廖雪峰官网的python3装饰器有感 装饰器即将一个函数作为变量在新的函数中调用此函数. 作业: 能否写出一个@log的decorator,使它既支持: @logdef f():     pass 又支持: @log('execute')def f():     pass      例1: import functools import time def log(*args,**kwargs):     # *args 是个元组     if args and isinstance(args,

【一起学设计模式】状态模式+装饰器模式+简单工厂模式实战:(一)提交个订单我到底经历了什么鬼?

前言 之前在我的博客(一枝花算不算浪漫)中已经更新过两篇设计模式相关的内容 [一起学设计模式]策略模式实战一:基于消息发送的策略模式实战 [一起学习设计模式]策略模式实战二:配合注解 干掉业务代码中冗余的if else... [一起学设计模式]访问者模式实战:权限管理树删节点操作 [一起学设计模式]命令模式+模板方法+工厂方法实战: 如何优雅的更新商品库存... 上面内容都是基于真实业务场景精简后的设计(工作中真实场景使用到的). 之前为了学习设计模式,看过网上很多相关博客讲解,大都是画下UML

Python3——装饰器及应用(这个属于详细的)

转自:https://blog.csdn.net/loveliuzz/article/details/77853346    说明:本文代码是原作者编写,有一些不适应我的环境的代码我进行了删除修改等操作,特此说明! 解释的很全面! 1.装饰器: (1)本质:装饰器的本质是函数,其基本语法都是用关键字def去定义的. (2)功能:装饰其他函数,即:为其他函数添加附加功能. (3)原则:不能修改被装饰的函数的源代码,不能修改被装饰的函数的调用方式.即:装饰器对待被修饰的函数是完全透明的. (4)简单

python装饰器通俗易懂的解释!

python装饰器 刚刚接触python的装饰器,简直懵逼了,直接不懂什么意思啊有木有,自己都忘了走了多少遍Debug,查了多少遍资料,猜有点点开始明白了.总结了一下解释得比较好的,通俗易懂的来说明一下: 小P闲来无事,随便翻看自己以前写的一些函数,忽然对一个最最最基础的函数起了兴趣: 1 def sum1(): 2 sum = 1 + 2 3 print(sum) 4 sum1() 此时小P想看看这个函数执行用了多长时间,所以写了几句代码插进去了: 1 import time 2 3 def

python重试装饰器的简单实现

简单实现了一个在函数执行出现异常时自动重试的装饰器,支持控制最多重试次数,每次重试间隔,每次重试间隔时间递增. 核心代码20行不到,最新的代码可以访问从github上获取 https://github.com/blackmatrix7/matirx-tookit/blob/master/decorator/retry.py #!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2017/8/24 20:36 # @Author : Bla

Python3装饰器

装饰器:本质是函数(装饰其他函数-->为其他函数添加功能) 原则:1.不能被修改装饰的源代码 2.不能修改被装饰的函数的调用方式知识储备:1.函数即"变量"2.高阶函数3.嵌套函数高阶函数+嵌套函数 = 装饰器 高阶函数:a.把一个函数名当做实参传给另一个函数 b.返回值中包含函数名嵌套函数: 仅用高阶函数实现的装饰器 高阶函数+嵌套函数:实现装饰器. 装饰器函数定义时,通过将需要装饰的函数(装饰器的形参)放在嵌套函数里面,嵌套在内层的函数只进行函数定义,不进行函数的调用(内含的

装饰器原理-代码解释

# coding:utf-8 # 带参数装饰器 def f1(func): print('开始!') def f2(a): print(func) a() print('执行') return f2 @f1('666') def f3(): print('测试开始') # 无参数装饰器 def f1(func): print('开始!') def f2(): func() print('执行') return f2 @f1 def f3(): print('测试开始') if __name__

PythonStudy——装饰器的简单实现

def outer(func): def inner(): print("新增功能1") func() print("新增功能2") return inner @outer # 这个一定要写!!func = outer(func)= inner def func(): print("原有功能") # 装饰器:满足开放封闭原则的一个闭包应用 # @outer语法来调用outer,规定传入被装饰的函数对象,所以参数固定为一个,接受被装饰的函数对象de

python3 装饰器修复技术@wraps到底是什么?

Python 装饰器中的@wraps的作用:    装饰器的作用:    在不改变原有功能代码的基础上,添加额外的功能,如用户验证等    @wraps(view_func)的作用:     不改变使用装饰器原有函数的结构(如__name__, __doc__)    不使用wraps可能出现的ERROR:   view_func...endpoint...map... 如果没使用@wraps,当A调用了装饰器B的话,即使A.name,返回的会是装饰器B的函数名称,而不是A的函数名称如果使用了@