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
'梯阅线条'

最近更新

  1. TCP协议是安全的吗?

    2024-01-19 05:58:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-19 05:58:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-19 05:58:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-19 05:58:01       18 阅读

热门阅读

  1. 11.25 校招 实习 内推 面经

    2024-01-19 05:58:01       34 阅读
  2. springboot 整合 actuator监控详情

    2024-01-19 05:58:01       30 阅读
  3. 笨蛋学设计模式结构型模式-适配器模式【7】

    2024-01-19 05:58:01       29 阅读
  4. OpenAI/ChatGPT Plus 支持的虚拟卡有哪些

    2024-01-19 05:58:01       127 阅读
  5. linux tty 驱动之ioctls 函数

    2024-01-19 05:58:01       30 阅读
  6. 2. 分享三篇早期的FPGA 布局布线论文

    2024-01-19 05:58:01       33 阅读
  7. 汽车租赁标投标书:如何制作出色的标书?

    2024-01-19 05:58:01       28 阅读
  8. 云的网络安全优势

    2024-01-19 05:58:01       33 阅读
  9. 【C语言】string.h——主要函数总结

    2024-01-19 05:58:01       21 阅读
  10. 汇编指令retn和retn x的区别

    2024-01-19 05:58:01       30 阅读