大家好,欢迎来到IT知识分享网。
用来指定当前类由谁来创建(默认type创建)
通过参数 MetaClass 来指定当前的类是由那个类创建的
使用type创建类
第一个参数表示类名,第二个参数表示继承的类,第三个参数表示的指定其属性和方法
Base = type('Base', (object,), {})
简单的使用(一)
class MyType(type): def __init__(self,*args,**kwargs): print('init') super(MyType,self).__init__(*args,**kwargs) def __call__(self, *args, **kwargs): print('call本质:调用类的__new__,再调用类的__init__') return super(MyType,self).__call__( *args, **kwargs) class Foo(metaclass=MyType): pass class Bar(Foo): pass obj = Bar()
运行结果如下
我们可以看到Foo和Bar类都是由MyType类创建的,创建的他们的时候会先执行他们的__init__方法,对象obj是Bar类创建的,实例化对象的时候会执行__call__方法
简单的使用(二)
在这里使用的是通过tyoe动态的创建类
class MyType(type): def __init__(self, *args, **kwargs): super(MyType, self).__init__(*args, **kwargs) def __call__(cls, *args, **kwargs): print('xxxx') return super(MyType, cls).__call__(*args, **kwargs) # Base = MyType('Base', (object,), {}) # MyType('Base', (object,), {}) 是有MyType创建; metaclass=MyType # 1. type可以创建类metaclass=type;MyType也可以创建类metaclass=MyType # 2. Base = MyType('Base', (object,), {}) --> # class Base(metaclass=MyType): # pass # class Foo(Base): # pass class Foo(MyType('Base', (object,), {})): pass obj = Foo()
简单的使用(三)
在这里在继承的时候通过函数返回一个类
class MyType(type): def __init__(self, *args, **kwargs): super(MyType, self).__init__(*args, **kwargs) def __call__(cls, *args, **kwargs): return super(MyType, cls).__call__(*args, **kwargs) def with_metaclass(base): return MyType('XX', (base,), {}) class Foo(with_metaclass(object)): pass
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/33684.html