python 面向对象专题(十四):元类(三): MetaClass使用

python 面向对象专题(十四):元类(三): MetaClass使用用来指定当前类由谁来创建(默认type创建)通过参数 MetaClass来指定当前的类是由那个类创建的使用type创建类第一个参数表示类名,第二个参数表示继承的类,第三个参数表示的指定其属性和方法Base=type('Base',(object,),{})

大家好,欢迎来到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() 

运行结果如下

python 面向对象专题(十四):元类(三): MetaClass使用

我们可以看到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

(0)
上一篇 2023-12-20 22:33
下一篇 2023-12-22 19:15

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信