zoukankan      html  css  js  c++  java
  • python 中classmethod修饰符、staticmethod和装饰器有什么区别

    学了python也有两个年头了,可是一直对classmethod修饰符、staticmethod和装饰器这三个区别不出来,不知道什么时候用这些。查找了很多资料,结合自身情况总结如下:

    一般创建类(里面包含N个方法)后,需要使用里面的方法实际某种特定功能,需要实例化类,然后再通过实例后的类访问它里面的方法,例如:

    class test_classmethod(object):

    def printd(self,a ,b):
    c = a+b
    print (c)
    if __name__ == '__main__':
    c =test_classmethod()
    c.printd(3,5)
    这时运行后的结果是:8,如果不想做实例化这一步,可以在 def printd(self,a ,b)上面加上@classmethod,如下:
    class test_classmethod(object):
    @classmethod
    def printd(cls,a ,b):
    c = a+b
    print (c)
    if __name__ == '__main__':
    test_classmethod.printd(3,5)
    结果一样是8;
    classmethod 修饰符对应的函数不需要实例化,不需要 self 参数,但第一个参数需要是表示自身类的 cls 参数,可以来调用类的属性,类的方法,实例化对象等。如下:
    class A(object):

    a = 1

    def def1(self):
    print("foo")

    @classmethod
    def def2(cls):
    print('def2')
    print(cls.a)
    cls().def1() # 调用 foo 方法


    A.def2() #不需要实例化,直接调用def2

    staticmethod 静态方法,如果声明 此类中的某一个def a()为静态方法,那么可以不用实例化就能直接调用,调用方法如
    test_classmethod.printd(3,5)一样,也可以实例化后再调用:
    class test_classmethod(object):
    @staticmethod
    def printd(a ,b):
    c = a+b
    print (c)
    if __name__ == '__main__':
    test_classmethod.printd(3,5)
    如果实例化,也可以写为:test_classmethod().printd(3,5)
    装饰器主要是和他们完全不同,主要作用是在本方法之外,附加一些额外功能(在不改变原代码的基础上),例如,我写一些基础的方法,a功能(属于A组程序员)、b功能(属于B组程序员)、c功能(属于C组程序员)都需要调用这个方法,
    有天公司加了D组、E组、F组。但领导规定,只能A、B、C组调用,其他组不能调用该功能,存在风险。那么就需要我来写一个验证的方法,装饰到该功能上,例如:
    def w1(func):
    def inner():
    # 验证是否属于A组
    # 验证是否属于B组
    # 验证是否属于C组
    return func()

    return inner

    @w1
    def a():
    print('f1')

    @w1
    def b():
    print('f2')

    @w1
    def c():
    print('f3')
    运行过程解释:
    @w1
    def a():
    print('f1') 为例:当执行到@w1时,系统会将a()函数整个传递给def w1(func)-->此时func代表a,然后执行def inner()做验证,验证完成后返回a()-->即return a(),并执行def a()方法。如果验证不通过,就直接返回inner(),inner是非执行函数,即 不执行def a()方法。
    总结:装饰器就是将要调用的方法a包裹在另一个方法中W1中,通过w1的功能执行通过后再执行a,否则就不执行调用的a功能。

    当然还有多个参数的装饰器
    例如:
    def w1(func):
    def inner(arg1,arg2,arg3):
    # 验证是否属于A组
    # 验证是否属于B组
    # 验证是否属于C组
    return func(arg1,arg2,arg3)

    return inner


    @w1
    def a(arg1,arg2,arg3):
    print('f1')

    不知道这样的总结能否看得懂,当然还有更复杂的装饰器,一个函数可以用多个装饰器。后续再学习。。。


  • 相关阅读:
    umeng社交分享最新版5.0的跨进程使用崩溃的问题及解法-Android
    AlertDialog禁止返回键
    一个男人想经商,不读 100本商人自传,怎么会了解商人的思维状态
    Android中使用Gson解析JSON数据的两种方法
    DevExpress gridControl控件动态绑定列 zt
    获得WCF Client端的本地端口 z
    log4net.dll配置以及在项目中应用 zt
    系统交易策略 hylt
    判斷作業系統為 64bit 或 32bit z
    路徑 z
  • 原文地址:https://www.cnblogs.com/SusanXX/p/8400302.html
Copyright © 2011-2022 走看看