重载type类的__new__()方法即可定义一个最简单的元类。
最简单的元类是带有一个__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'>
通过重载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
'梯阅线条'