• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 26, comments - 2, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            Python的staticmethod和classmethod

            Posted on 2014-04-16 12:01 小夜 閱讀(416) 評論(0)  編輯 收藏 引用 所屬分類: [52] Python
            最近專職做起了Python,得積累些Python的知識。
            -----------------
            閱讀代碼的時候,看到了classmethod。staticmethod用的挺多,classmethod一直沒用過,感覺有些迷惑。
            Google了一篇文章,講的挺清楚:pyhton靜態方法和類方法。上面這篇文章主要講原理,我這里主要說說二者的相同和區別。
            1. 都可以通過類調用;
            2. 都可以通過對象調用;
            3. 都可以繼承和復寫;
            4. 都可以使用類屬性、類方法和類的靜態方法;
            5. 使用這些屬性或方法時,staticmethod必須直接通過類名進行調用,classmethod可以優雅的通過參數cls調用。
            在進行屬性或方法調用時:staticmethod需要硬編碼指明方法的類,如果存在繼承,無法使用子類復寫的方法和屬性,比較適合用于對其他方法和屬性不依賴或依賴較少的情況;classmethod通過cls進行調用,這個cls是調用時傳入的類,可以是父類,也可以是子類,適合用于對其他方法和屬性依賴較多的情況,也適用于需要通過集成擴展的情況。

            下面的代碼,簡單試驗了兩者的區別,并通過staticmethod簡單的模擬了classmethod的操作:

            class Base(object):
                name = "Base"
                
                @classmethod
                def foo(cls):
                    print cls.name
                
                @staticmethod
                def foo_static1():
                    print Base.name
                
                @staticmethod
                def foo_static2(cls):
                    print cls.name

                @staticmethod
                def foo_static3(cls):
                    # if not isinstance(cls, type):
                    if isinstance(cls, Base):
                        cls = cls.__class__
                    print cls.name


            class A(Base):
                name = "A"
                def __init__(self):
                    self.name = "I am '%s'" % A.name
                    

            class B(Base):
                name = "B"
                def __init__(self):
                    self.name = "I am '%s'" % B.name
                
                @classmethod
                def foo(cls):
                    print "<%s>" % cls.name
                
                @staticmethod
                def foo_static1():
                    print "<%s>" % Base.name


            def testA():
                obj = A()
                obj.foo()
                obj.foo_static1()
                obj.foo_static2(A)
                obj.foo_static2(obj)
                obj.foo_static3(A)
                obj.foo_static3(obj)
                A.foo()
                A.foo_static1()

            def testB():
                obj = B()
                obj.foo()
                obj.foo_static1()


            def run_test(func, *args, **kwargs):
                print "======================="
                func(*args, **kwargs)
                print ""


            if __name__ == '__main__':
                run_test(testA)
                run_test(testB)
                
            久久国产欧美日韩精品免费| 久久精品国产亚洲Aⅴ蜜臀色欲| 久久天天躁狠狠躁夜夜96流白浆| 日韩欧美亚洲国产精品字幕久久久| 中文精品久久久久国产网址| 久久精品国产亚洲Aⅴ香蕉 | 久久人爽人人爽人人片AV| 久久人人爽人人爽人人AV| 久久九九亚洲精品| 日韩欧美亚洲综合久久| 久久er热视频在这里精品| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久香蕉国产线看观看99| 亚洲国产天堂久久综合| 久久香蕉超碰97国产精品| 国产精品99久久不卡| 波多野结衣AV无码久久一区| 99久久精品国产一区二区三区| 亚洲精品乱码久久久久久蜜桃图片 | 精品久久久久久久久久中文字幕| 欧美亚洲色综久久精品国产| 久久精品亚洲精品国产欧美| 99久久人妻无码精品系列蜜桃| 日日狠狠久久偷偷色综合96蜜桃| 人妻无码αv中文字幕久久琪琪布| 亚洲人成无码网站久久99热国产| 久久99热国产这有精品| 国产精品久久自在自线观看| 久久久久高潮毛片免费全部播放 | 伊人久久精品无码av一区| 色99久久久久高潮综合影院| 91精品国产色综久久| 国产精品天天影视久久综合网| 久久综合伊人77777| 欧美性猛交xxxx免费看久久久| 99久久精品免费看国产免费| 久久婷婷久久一区二区三区| 久久电影网一区| 久久香蕉国产线看观看乱码| 久久国产一区二区| 狠狠精品干练久久久无码中文字幕|