metaclass ,一个特殊的类,可以对类属性和类方法进行所谓“动态”修改,是Python世界的上帝——type类的子类,具有“超越——metadata”和“变形——metamorphosis”的意思。
用户自定义实例,是用户自定义类的实例,定义它是对 所属类的__new__()方法的调用
而用户自定义类,是type类的实例,同时定义它是对type类的__call__()方法的调用
class LingJiXian():
pass
book_2 = LingJiXian()
type(book_2)
#输出
#<class '__main__.LingJiXian'>
type(LingJiXian)
#输出
#<class 'type'>
下面我们来说明类的实际创建过程
class Lizi():
pass
我们用上面的方式去创建一个类,其实,python真正执行的是下面这句代码(name,bases,attrs的意思同上文)
#name是将创建的类的名称
#bases是将创建类的父类
#attrs是将创建的类的所有属性和方法组成的字典
Lizi = type(name, bases, attrs)
而上面这句代码等于下面这句
Lizi = type.__call__(name, bases,attrs)
所以,我们说用户自定义类,就是对type类的__call__()方法的调用,它会进一步调用__new__()和__init__()
type.__new__(typeclass, name, bases, attrs)
type.__init__(class, name, bases, attrs)
MetaClass是type类的子类,设计MetaClass必须定义并实现__new__()方法,该方法需返回一个该类的实例对象,解释器会在创建被动态修改的类时调用该方法。
举例说明
class FirstMetaClass(type):
def __new__(cls, name, bases, attrs):
attrs['motto'] = "对不起,请原谅,谢谢你,我爱你"
attrs['effect'] = lambda self: print("清理连接,转化能量")
return super().__new__(cls, name, bases, attrs)
class LingJiXian(metaclass=FirstMetaClass):
pass
book_3=LingJiXian()
print(book_3.motto)
book_3.effect()
#输出
#对不起,请原谅,谢谢你,我爱你
#清理连接,转化能量
一旦把某个类的metaclass显示地指定为某个自定义Metaclass——MyMeta,它就不再是由原生的type类创建,而是调用MyMeta的__call__()方法。
MyClass = type(name, bases, attrs)
MyClass = MyMeta(name, bases, attrs)