博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python基础15_装饰器
阅读量:6229 次
发布时间:2019-06-21

本文共 1495 字,大约阅读时间需要 4 分钟。

 一. 装饰器

    开闭原则: 软件设计的原则之一, 又称为开放封闭原则. 
    开放: 对功能扩展开放
    封闭: 对修改代码封闭
    装饰器: 在目标函数前或后插入一段新的代码, 不改变目标函数的代码
    可以给目标函数传参, 拿到目标函数的返回值
    python里面的动态代理
    在不破坏目标函数和目标函数调用的基础上给函数添加新的功能
    通用语法:
        def wrapper(fn):                        # fn 是目标函数
            def inner(*args, **kwargs):            # 聚合    给目标函数传参
                """在目标函数之前进行操作"""
                ret = fn(*args, **kwargs)        # 打散    执行目标函数, 接收目标函数的返回值"xxx"
                """在目标函数之后进行操作"""
                return ret                        # 返回目标函数的返回值"xxx", 保证函数正常结束
            return inner                        # 返回inner的返回值"xxx"
        @wrapper                                # 语法糖 装饰器中特有 相当于 target_func = wrapper(target_func)
        def target_func()
            pass
            return "xxx"
        # target_func = wrapper(target_func)
        ret = target_func()                        # 执行inner, 并接收inner的返回值"xxx"
        print(ret)                                # 最终打印的是目标函数的返回值"xxx"
二. 带参数的装饰器
    
    语法:
    def wrapper_out(形参):                    
        def wrapper(fn):
            def inner(*args, **kwargs):
                """在目标函数之前进行操作"""
                ret = fn(*args, **kwargs)
                """在目标函数之后进行操作"""
                return ret
            return inner
        return wrapper
    @wrapper_out(实参)
    def func():
        pass
    func()
三. 多个装饰器装饰同一个函数
    def wrapper1(fn):
        def inner(*args, **kwargs):
            print(111111)
            ret = fn(*args, **kwargs)
            print(222222)
            return ret
        return inner
    def wrapper2(fn):
        def inner(*args, **kwargs):
            print(333333)
            ret = fn(*args, **kwargs)
            print(444444)
            return ret
            return inner
    @wrapper1
    @wrapper2
    def target_func():
        print("我是target_func")
        return "target_func"
    ret = target_func()
    print(ret)
    # 打印结果
        111111
        333333
        我是target_func
        444444
        222222
        target_func
    执行顺序: 首先@wrapper2装饰起来, 然后获取到一个新函数是wrapper2中的inner, 然后执行@wrapper1, 这个时候, wrapper1装饰的就是wrapper2中的inner了, 所以执行顺序就像: 
    外层装饰器前 -- 内层装饰器前 -- 目标 -- 内层装饰器后 -- 外层装饰器后 -- 目标函数返回值

转载于:https://www.cnblogs.com/guyannanfei/p/10121475.html

你可能感兴趣的文章
一个简洁且强大的状态管理库 - iFlow
查看>>
IP地址转换函数——inet_pton inet_ntop inet_aton inet_addr inet_ntoa
查看>>
设计模式笔记---4. 装饰模式
查看>>
springmvc + mybatis + ehcache + redis 分布式架构
查看>>
爬虫学习日记(四)分析Freenium
查看>>
nginx事件模块 -- 第五篇 epoll add
查看>>
共享栈基本操作
查看>>
Java 生成 PDF 文档
查看>>
深度学习:用生成对抗网络(GAN)来恢复高分辨率(高精度)图片 (附源码,模型与数据集)...
查看>>
缓存与数据库双写,不一致问题及解决方案
查看>>
Swift基础-部分关键字说明与示例
查看>>
【云服务月刊】2018年第1期:阿里云客户服务部总经理张颖杰:用心聆听,服务见智...
查看>>
99%的Java程序员都不知道的Spring中的@Transactional注解的坑
查看>>
堆排序 Heap Sort
查看>>
golang map 底层部分理解
查看>>
3.22(终)
查看>>
第61节:Java中的DOM和Javascript技术
查看>>
排名前十的程序员应用软件曝光,你有用过吗?
查看>>
关于android中监控u盘插入与拔出的困惑与思考
查看>>
Golang 并发爬虫 爬取某著名游戏媒体
查看>>