python声明和定制构建初始化基本元类

1 python声明和定制构建初始化基本元类

重载type类的__new__()方法即可定义一个最简单的元类。

1.1 基本元类

最简单的元类是带有一个__new__方法的type的子类,通过运行type的默认版本创建类对象。

用法

# 定义
class MyMeta(type):
    def __new__(meta,classname,supers,classdict):
        return type.__new__(meta,classname,supers,classdict)
# 使用
class ClassB(ClassA,metaclass=MyMeta):

描述

定义基本元类,只需定义一个类,继承type,重载__new__()方法。

使用时,用关键字参数metaclass传入元类到用户类。

示例

>>> class MyMeta(type):
    def __new__(meta,classname,supers,classdict):
        print('调用 MyMeta.__new__:',
              'meta: %s' % meta,
              'classname: %s' % classname,
              'supers: %s' % supers,
              'classdict: %s' % classdict,sep='\n')
        return type.__new__(meta,classname,supers,classdict)

    
>>> class ClassA:pass

>>> class ClassB(ClassA,metaclass=MyMeta):
    name='梯阅线条'
    def meth(self,arg):
        pass

    
调用 MyMeta.__new__:
meta: <class '__main__.MyMeta'>
classname: ClassB
supers: <class '__main__.ClassA'>
classdict: {'__module__': '__main__', '__qualname__': 'ClassB', 'name': '梯阅线条', 'meth': <function ClassB.meth at 0x0000023B456FCCA0>}
# MyMeta 类
>>> type(ClassB)
<class '__main__.MyMeta'>
# type 类
>>> type(ClassA)
<class 'type'>

1.2 定制构建和初始化

通过重载type类的__new__()方法和__init__()方法定制元类的构建和初始化。

用法

class MyMeta(type):
    def __new__(meta,classname,supers,classdict):
        pass
        return type.__new__(meta,classname,supers,classdict)
    def __init__(Class,classname,supers,classdict):
        pass

描述

定义一个继承type的类,并且重载__new__()和__init__()方法,被type对象的__call__()调用。

(1)__new__()创建并返回类对象;

(2)__init__()初始化类对象。

示例

>>> class MyMeta(type):
    def __new__(meta,classname,supers,classdict):
        print('调用 MyMeta.__new__:',
              'meta: %s' % meta,
              'classname: %s' % classname,
              'supers: %s' % supers,
              'classdict: %s' % classdict,sep='\n')
        return type.__new__(meta,classname,supers,classdict)
    def __init__(Class,classname,supers,classdict):
        print('调用 MyMeta.__init__:',
              'Class: %s' % Class,
              'classname: %s' % classname,
              'supers: %s' % supers,
              'classdict: %s' % classdict,sep='\n')
        print('初始化类对象:',list(Class.__dict__.keys()))

        
>>> class ClassA:pass

>>> class ClassB(ClassA,metaclass=MyMeta):
    name='梯阅线条'
    def meth(self,arg):
        pass

调用 MyMeta.__new__:
meta: <class '__main__.MyMeta'>
classname: ClassB
supers: <class '__main__.ClassA'>
classdict: {'__module__': '__main__', '__qualname__': 'ClassB', 'name': '梯阅线条', 'meth': <function ClassB.meth at 0x0000022F388C83A0>}
调用 MyMeta.__init__:
Class: <class '__main__.ClassB'>
classname: ClassB
supers: <class '__main__.ClassA'>
classdict: {'__module__': '__main__', '__qualname__': 'ClassB', 'name': '梯阅线条', 'meth': <function ClassB.meth at 0x0000022F388C83A0>}
初始化类对象: ['__module__', 'name', 'meth', '__doc__']
>>> cb=ClassB()
>>> cb.name
'梯阅线条'

你可能感兴趣的:(python,python)