文档章节

python 装饰器

hyhlinux
 hyhlinux
发布于 2016/12/08 10:29
字数 320
阅读 5
收藏 1

1.记录运行时间
def bench(fun):
    print 'bench:', time.clock()

    def wrapper(*arg, **kwarg):
        start = time.clock()
        ret = fun(*arg, **kwarg)
        print 'ben who: ', fun.__name__, 'time:', time.clock() - start
        return ret

    return wrapper

2.添加log

def log(fun):
    print'log:', time.clock()
    def wrapper(*arg, **kwarg):
        ret = fun(*arg, **kwarg)
        print 'log..who:', fun.__name__, arg, kwarg
        return ret

    return wrapper

 

3.多重

def first(func):
    print '%s() was post to first()' % func.func_name
    def _first(*args, **kw):
        print 'Call the function %s() in _first().' % func.func_name
        return func(*args, **kw)
    return _first


def second(func):
    print '%s() was post to second()' % func.func_name
    def _second(*args, **kw):
        print 'Call the function %s() in _second().' % func.func_name
        return func(*args, **kw)
    return _second

'''
meth1:
@first
@second
test() was post to second()
_second() was post to first()

test->_second->_first

@second
@first
test() was post to first()
_first() was post to second()

test->_frist()->second

------------------

meth2:
when call test()
test() was post to second()
_second() was post to first()
Call the function _second() in _first().
Call the function test() in _second().
hello in test
test->_second->_first
test()  
    1._first()-->_second()
       print 'Call the function %s() in _first().' % func.func_name     #func==>_second
       return func(*args, **kw)                                         #_second() 

    2._second()-->test()
        print 'Call the function %s() in _second().' % func.func_name   #func==>test
        return func(*args, **kw)                                        #test()

'''


@first
@second
def test():
    print 'hello in test'

 

 

补充:

装饰器的运行时间:

    在使用@的时候,装饰器就已经开始工作,而不是在被装饰是函数调用的时候。

    即,不调用test(), 只要使用@first后,first()函数就会被调用.

 

© 著作权归作者所有

共有 人打赏支持
下一篇: tornado gen
hyhlinux
粉丝 7
博文 167
码字总数 51777
作品 0
海淀
程序员
私信 提问

暂无文章

十万个为什么之为什么大家都说dubbo

Dubbo是什么? 使用背景 dubbo为什么这么流行, 为什么大家都这么喜欢用dubbo; 通过了解分布式开发了解到, 为适应访问量暴增,业务拆分后, 子应用部署在多台服务器上,而多台服务器通过可以通过d...

尾生
35分钟前
2
0
Docker搭建代码质量检测平台-SonarQube(中文版)

Sonar是一个用于代码质量管理的开源平台,用于管理源代码的质量,可以从七个维度检测代码质量。通过插件形式,可以支持包括java,C#,C/C++,PL/SQL,Cobol,JavaScrip,Groovy等等二十几种编程语言...

Jacktanger
42分钟前
2
0
Windows / Linux / MacOS 设置代理上网的方法汇总

本文汇总了 Windows / Linux / MacOS 设置代理上网的各种方法,总结如下: 1、设置系统代理(Windows、Linux、MacOS) 2、设置代理插件(Chrome、Chromium、Firefox、Opera、QQ等浏览器) 3、...

sunboy2050
昨天
4
0
自定义 Maven 的 repositories

有时,应用中需要一些比较新的依赖,而这些依赖并没有正式发布,还是处于milestone或者是snapshot阶段,并不能从中央仓库或者镜像站上下载到。此时,就需要 自定义Maven的<repositories>。 ...

waylau
昨天
3
0
徒手写一个es6代码库

mkdir democd demonpm initnpm install -g babelnpm install -g babel-clinpm install --save-dev babel-preset-es2015-node5 在项目目录创建两个文件夹 functional-playground ......

lilugirl
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部