metaclass

基本常識ide

1.對象是類建立,建立對象時候類的__init__方法自動執行,對象()執行類的 __call__ 方法
2.類是type建立,建立類時候type的__init__方法自動執行,類() 執行type的 __call__方法(類的__new__方法,類的__init__方法)

# 第0步: 執行type的 __init__ 方法【類是type的對象】
class Foo:
    def __init__(self):
        pass

    def __call__(self, *args, **kwargs):
        pass

# 第1步: 執行type的 __call__ 方法
#        1.1  調用 Foo類(是type的對象)的 __new__方法,用於建立對象。
#        1.2  調用 Foo類(是type的對象)的 __init__方法,用於對對象初始化。
obj = Foo()
# 第2步:執行Foodef __call__ 方法
obj()

示例一

class MyType(type):
    def __init__(self, *args, **kwargs):
        print('MyType建立類',self)
        super(MyType, self).__init__(*args, **kwargs)

    def __call__(self, *args, **kwargs):
        obj = super(MyType, self).__call__(*args, **kwargs)
        print('類建立對象', self, obj)
        return obj


class Foo(object,metaclass=MyType):
    user = 'ctz'
    age = 18

obj = Foo()
View Code

結果:post

MyType建立類 <class '__main__.Foo'>
類建立對象 <class '__main__.Foo'> <__main__.Foo object at 0x0000024858243470>

示例二:spa

class MyType(type):
    def __init__(self, *args, **kwargs):
        print('MyType',self,'----')
        super(MyType, self).__init__(*args, **kwargs)

    def __call__(cls, *args, **kwargs):
        v = dir(cls)
        obj = super(MyType, cls).__call__(*args, **kwargs)
        print('MyType',cls,obj,'****')
        return obj


class Foo(MyType('MyType', (object,), {})):
    user = 'ctz'
    age = 18


obj = Foo()
View Code

結果code

MyType <class '__main__.MyType'> ----
MyType <class '__main__.Foo'> ----
MyType <class '__main__.Foo'> <__main__.Foo object at 0x0000025A92BB36D8> ****

示例三:(查看wtforms源碼可知,實例化Form就是經過這種方法作的,此外這種方式能夠實現單例模式)orm

class MyType(type):
    def __init__(self, *args, **kwargs):
        print(self,'------')
        super(MyType, self).__init__(*args, **kwargs)

    def __call__(cls, *args, **kwargs):
        v = dir(cls)
        obj = super(MyType, cls).__call__(*args, **kwargs)
        print(cls,obj,'****')
        return obj


def with_metaclass(arg,base):
    return MyType('MyType', (base,), {})


class Foo(with_metaclass(MyType,object)):
    user = 'ctz'
    age = 18


obj = Foo()
View Code

結果:對象

<class '__main__.MyType'> ------
<class '__main__.Foo'> ------
<class '__main__.Foo'> <__main__.Foo object at 0x000001FBD9E63710> ****
相關文章
相關標籤/搜索