zoukankan      html  css  js  c++  java
  • python装饰器的理解

    学习python,发现装饰器是一个比较难理解的地方。

    下面用代码来说明。

    装饰器的作用是为了切面编程(AOP)。这种编程在java上有很多实现方式。下面直接说明吧:

    1.作为装饰器的函数至少有两个def。并且最外层的def有且仅有一个参数,也就是像下面的这样:

          def  decorateDemo(fun):

                   def real_deco():

                            ######

                            ######

                  return real_deco

    说明一下上面的装饰器的意义,第一个def是为了包括返回的函数对象,所以也就是倒数第二个def必须有一个参数。这个参数就是被装饰的函数,如果没有这个参数,装饰器将没有办法使用。

    第二个def是真正的包括函数,这个函数的参数是被于被包裹函数的参数一致的,所以,为了包括函数的通用性,一般都写成 real_deco(*args,**argss),用来接收任意的参数。

    第三个需要注意的地方是return real_deco,这个地方一定注意是返回real_deco,而不是real_deco().返回的函数引用,而不是函数调用。

    改进的代码如下:

          def  decorateDemo(fun):

                   def real_deco(*args,**argss):

                            ######

                            ######

                  return real_deco

    调用示例:

        def  decorateDemo(fun):

                   def real_deco(*args,**argss):

                        print " i am in decorate@@@"   

                        fun(args,argss)

                  return real_deco

       @decorateDemo

       def funtest(args)

               print "i have one args"+args

    if __name__== '__main__':

              funtest("lxzhtest")

    第二个需要注意的地方是如果装饰器也带参数应该怎么办。

    这个时候需要将装饰器函数提高一个级别,类似于下面这样:

           def decorateDemoHigher(decoArgs):

               def  decorateDemo(fun):

                   def real_deco():

                            ######

                            ######

                  return real_deco

              return decorateDemo

    更加高级的例子,参考:   http://m.blog.csdn.net/blog/dreamcoding_11109/8611578#

  • 相关阅读:
    linux内存-swap
    linux内存-buffer和cache
    Linux内存-内存管理机制oom_killer
    HTTPS(二)证书合法性校验
    HTTPS(一)基础及连接建立
    docker镜像(一)overlayfs
    DNS(三)全局流量调度
    建造者模式(Builder Pattern)
    抽象工厂模式(Abstract Factory)
    工厂方法模式(Factory Method Pattern)
  • 原文地址:https://www.cnblogs.com/lxzh/p/4709921.html
Copyright © 2011-2022 走看看