• 简单装饰器


    # -*- coding:utf-8 -*-
    def w1(show):
        def outer(a,b):
            print('添加新功能1')
            show(a,b)
            print('添加新功能2')
        return outer
    #@w1的作用就相当于w1(show),即执行w1(show)函数并且把show()函数的地址作为参数传进去,以为制作
    # 新show()函数做准备,返回的outer相当于新show()函数的地址。新outer()函数就是制作的
    # 新show()函数,新show()函数在集成了旧show()函数的功能上,添加了新的功能
    @w1
    def show(a,b):
        print('a+b=%d'%(a+b))
    show(2,3)

    这个简单装饰器的执行流程是这样的:首先把函数w1()读到内存不执行(不被调用不会执行),然后到@w1------>w1(show)------>return outer------>至此,新的show()函数框架制作完成,然后再往里面添加新功能就行了。------>show(2,3),此为函数调用,注意,会调用新

    show()函数,也就是outer()函数------>print('添加新功能1')------>show(2,3),调用旧的show(a,b)函数,即未被装饰过的show(a,b)函数------>

    print('a+b=%d'%(a+b)),执行结果是a+b=5------>print('添加新功能2')------>结束。

    下面是自己随便写的一个非常简单的带装饰器的函数:

     1 def add(f3):
     2     def f2(a,b):
     3         print('add the first function')
     4         f3(a,b)
     5         print('add the second function')
     6     return f2
     7 
     8 @add
     9 def f1(a,b):
    10     print('the initial function')
    11     print('a+b=%d'%(a+b))
    12 f1(3,2)
    View Code
  • 相关阅读:
    多线程《三》进程与线程的区别
    多线程《二》开启线程的两种方式
    多线程《一》线程理论
    多进程《七》生产者消费者模型
    多进程《六》队列
    互斥锁与join
    多进程《五》互斥锁
    多进程《四》守护进程
    再度认识未来——2.11
    开始——2.10
  • 原文地址:https://www.cnblogs.com/yibeimingyue/p/9323807.html
Copyright © 2020-2023  润新知