python元类模型和class语句协议

1 python元类模型和class语句协议

学习python的类型模型和class语句协议。class语句末尾自动调用type()创建类对象并且赋值给类名称。

1.1 类是类型的实例

python3.x中,用户定义的类对象是名为type的对象的实例,type本身是一个类;

python2.x中,新式类继承object,它是type的一个子类;传统类是type的一个实例;

type()内置函数返回任何对象的类型。

1.1.1 python3.x

顶层的type对象创建具体的类型,具体的类型创建实例。

>>> type([])#list类创建列表实例(具体类创建实例)
<class 'list'>
>>> type(type([]))#type类创建list类(type类创建具体类)
<class 'type'>
>>> type(list)
<class 'type'>
>>> type(type)
<class 'type'>

1.1.2 python2.x

type是一种内置对象,位于类型层级的顶层,用来构建类型。

>>> type([])
<type 'list'>
>>> type(type([]))
<type 'type'>
>>> type(list)
<type 'type'>
>>> type(type)
<type 'type'>

1.1.3 python3.x自定义类

(1) 类型由派生自type的类定义;

(2) 用户定义的类是类型类的实例;

(3) 用户定义的类是产生它们自己的实例的类型。

>>> class C1:pass
>>> type(C1)
<class 'type'>
>>> type(C1())
<class '__main__.C1'>

1.1.4 __class__

类是type类的实例,类产生自的实例对象。

obj.__class__,返回obj所属的类,obj可以是实例对象,或者类对象。

python3.x

>>> class C:pass>>> c1=C()
>>> type(c1)
<class '__main__.C'>
>>> c1.__class__
<class '__main__.C'>
>>> type(C)
<class 'type'>
>>> C.__class__
<class 'type'>
>>> c1
<__main__.C object at 0x00000288F3360A90>
>>> C
<class '__main__.C'>

python2.x新式类

>>> class C(object):pass>>> c1=C()
>>> type(c1)
<class '__main__.C'>
>>> type(C)
<type 'type'>
>>> c1.__class__
<class '__main__.C'>
>>> C.__class__
<type 'type'>
>>> c1
<__main__.C object at 0x0000000003F70408>
>>> C
<class '__main__.C'>

python2.x传统类

>>> class C:pass>>> c1=C()
>>> type(c1)
<type 'instance'>
>>> type(C)
<type 'classobj'>
>>> c1.__class__
<class __main__.C at 0x00000000037A9AC8>
>>> C.__class__Traceback (most recent call last):File "<pyshell#19>", line 1, in <module>C.__class__
AttributeError: class C has no attribute '__class__'

1.2 元类是type的子类

python3.x中,类是type类的实例。

(1) type是产生用户定的类的一个类;

(2) 元类是type类的一个子类;

(3) 类对象是type类的一个实例,或一个子类;

(4) 实例对象产生自一个类。

用户定义的类创建子一个用户定义的元类,而不是type类,来控制创建类及扩展其行为的方式。

1.3 class语句协议

子类化type类以定制它。把一个类的创建指向元类,而不是默认的type。

理解class语句如何完成工作。

class语句末尾,自动执行type()方法,创建类对象赋值给类名。

class = type(classname,superclasses,attributedict)

type对象定义__call__运算符重载方法,调用type对象时,执行下面两个方法:

(1) type.__new__(typeclass,classname,superclasses,attributedict)

(2) type.__init__(class,classname,superclasses,attributedict)

__new__方法创建并返回新的class对象,__init__()方法初始化新创建的对象。

type的元类子类定制type的钩子。

>>> class A:pass>>> class B(A):name='梯阅线条'def meth(self,arg):pass# class 语句末尾自动调用type(),产生class 对象
B=type('B',(A,),{'name':'梯阅线条','meth':meth,'__module__':'__main__'})

用法

name=type(name, bases, dict) -> a new type

描述

手动调用type创建类对象。

name:字符串,类名;

bases:元组,存放基类;

dict:类属性字典;

返回:创建名字为name的类对象,类型为type类。

__base__获取类的直接超类组成的元组,参考《python命名空间字典》

示例

>>> class ClassB:name='梯阅线条'
>>> ClassB
# 自动调用 type() 创建类对象 赋值给 ClassB
<class '__main__.ClassB'>
>>> type(ClassB)
# 类对象类型为 type类 类型
<class 'type'>
>>> type(ClassB())
# 实例对象类型为 ClassB类 类型
<class '__main__.ClassB'>
>>> ClassB.__bases__
# 基类为 object
(<class 'object'>,)
>>> ClassB.name
# 类属性
'梯阅线条'

等效于

>>> ClassB=type('ClassB',(object,),{'__module__':'__main__','name':'梯阅线条'})
>>> ClassB
<class '__main__.ClassB'>
>>> type(ClassB)
<class 'type'>
>>> type(ClassB())
<class '__main__.ClassB'>
>>> ClassB.__bases__
(<class 'object'>,)
>>> ClassB.name
'梯阅线条'

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/630601.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【温故而知新】HTML5存储localStorage/sessionStorage

文章目录 一、概念二、存储localStorage三、存储sessionStorage四、区别及优缺点1. 区别&#xff1a;2. 优缺点&#xff1a; 一、概念 HTML5是HTML的最新版本&#xff0c;它引入了许多新的元素和功能&#xff0c;以适应现代网页开发的需求。以下是HTML5的一些主要特点&#xf…

Alinx ZYNQ 7020 LED调试--in RAM

设置拨码开关为JTAG方式 烧写LED bit stream a. 点击“Program device”烧录程序到FPGA中&#xff08;重新上电程序就丢失了&#xff09; b. /01_led/led.runs/impl_1/led.bit 程序烧录到Flash中 ZYNQ与以往的直接烧录Flash不同&#xff0c;首先必须PS&#xff0c;然后烧…

python实例100第23例:打印菱形图案

题目&#xff1a;打印出如下图案&#xff08;菱形&#xff09;: ********* ****************程序分析&#xff1a;先把图形分成两部分来看待&#xff0c;前四行一个规律&#xff0c;后三行一个规律&#xff0c;利用双重for循环&#xff0c;第一层控制行&#xff0c;第二层控制列…

golang中make与new有什么区别?

前言 记录下go语言中函数new与make的使用和区别&#xff0c;关于go语言中new和make是内建的两个函数&#xff0c;主要用来创建分配类型内存。 目录 前言make介绍用法&#xff1a;1. 创建切片&#xff08;slice&#xff09;&#xff1a;2. 创建映射&#xff08;map&#xff09;…

AWS Secrets Manager 实战指南

AWS Secrets Manager 是一项强大的服务,用于安全地管理和存储敏感信息,如数据库凭证、API 密钥等。本实战指南将指导你如何在实际应用中使用 AWS Secrets Manager。 创建 Secret 首先,我们需要在 Secrets Manager 中创建一个新的 Secret 来存储敏感信息。 登录 AWS 控制台…

2744. 最大字符串配对数目

Problem: 2744. 最大字符串配对数目 文章目录 思路解题方法复杂度Code拓展官方解法拓展解释 思路 要求返回数组中的反转字符数目&#xff1b;数组中每个元素都是固定的2个长度的小写字符串&#xff0c;且不相同&#xff1b;由不相同可知如果是aa&#xff0c;bb这种类型的必定不…

spring-boot定时任务

org.springframework.boot jar包 内置定时任务注解 。生成定时任务有 * * * * * &#xff1f; 表示秒分时日月周。 日和周的位置 必须某个位置用&#xff1f;代替*号用于区别。 定时任务规则&#xff1a;0 * * * &#xff1f; * * 表示任意月的任意周的每天的每时的每分…

抖音矩阵云混剪系统源码(免授权版)多平台多账号一站式管理,附带系统搭建教程

搭建教程 MySQL 5.6 PHP 7.2 Apache 数据库名称 juzhen Nginx环境切换伪静态 1、解压安装包到项目根目录&#xff0c;找到application/database.php 更换自己的数据库密码 2、阿里云现有的配置不要动 其他按照文档进行添加 3、项目访问目录&#xff1a;public 4、域名…

SQL笔记 -- 查询优化

1. 关联查询优化 1.1 驱动表和被驱动表 对于内连接来说&#xff0c;优化器会根据用户的查询语句做优化&#xff0c;决定先查哪张表。先查询的那张表就是驱动表&#xff0c;反之就是被驱动表。而对于外连接来说&#xff0c;大多数情况用户指定的主表就是驱动表&#xff0c;但优…

Demo: 实现PDF加水印以及自定义水印样式

实现PDF加水印以及自定义水印样式 <template><div><button click"previewHandle">预览</button><button click"downFileHandle">下载</button><el-input v-model"watermarkText" /><el-input v-mo…

敏捷开发之Scrum

敏捷开发是什么 我们一般习惯用瀑布模型&#xff0c;它以文档为驱动&#xff0c;将软件生命周期划分为固定的六个基本活动&#xff0c;并且规定了它们自上而下、相互衔接的次序&#xff0c;如同瀑布流水&#xff0c;逐级下落。 那什么是敏捷开发呢&#xff1f; ​ 敏捷开发的核…

解决前端笔记本电脑屏幕显示缩放比例125%、150%对页面大小的影响问题

近期在工作中遇到一个问题&#xff0c;记录一下&#xff0c;在项目上线之后&#xff0c;遇到一个问题&#xff0c;即缩放到90%时&#xff0c;页面字体比默认的100%字体大&#xff0c;一开始毫无头绪&#xff0c;经过一番的Google...Google...Google....&#xff0c;终于找到了解…

代码随想录算法训练营第五天| 总结数组专题

数组&#xff1a;二分查找、双指针&#xff08;包括快慢指针&#xff09;、滑动窗口、模拟 链表&#xff1a;双指针、三指针、虚拟头指针、复杂指针操作画图明确每一步&#xff08;标好次序&#xff09; 数组 代码随想录总结的很好&#xff0c;如下图。我再结合自己的一些理解…

AI 的未来是开源的

想象一下&#xff0c;在未来&#xff0c;人工智能不会被锁在公司的金库里&#xff0c;而是由全球创新者社区一砖一瓦地在开放中构建的。协作&#xff0c;而不是竞争&#xff0c;推动进步&#xff0c;道德考虑与原始绩效同等重要。这不是科幻小说&#xff0c;而是人工智能发展核…

【PostgreSQL内核学习(二十四) —— (ALTER MATERIALIZED VIEW)】

ALTER MATERIALIZED VIEW 概述源码解析修改物化视图的属性和行为AlterTableStmt 结构体AlterTableMoveAllStmt 结构体 重命名RenameStmt 结构体 设置对象依赖于扩展AlterObjectDependsStmt 结构体 测试用例 声明&#xff1a;本文的部分内容参考了他人的文章。在编写过程中&…

C++I/O流——(4)格式化输入/输出(第二节)

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 含泪播种的人一定能含笑收获&#xff…

73.网游逆向分析与插件开发-背包的获取-物品数据的初步数据分析

内容参考于&#xff1a;易道云信息技术研究院VIP课 上一个内容&#xff1a;72.网游逆向分析与插件开发-背包的获取-项目需求与需求拆解-CSDN博客 然后首先找切入点&#xff1a; 通过药物来当切入点&#xff0c;药物比较好使用&#xff0c;然后鼠标放到药物上它有名字、种类、…

Java注解技术

1. 注解的简介 从JDK 5开始&#xff0c;Java增加了对元数据&#xff08;MetaData&#xff09;的支持&#xff0c;也就是注解&#xff08;Annotation&#xff09;。 注解就是代码里的特殊标记&#xff0c;这些标记可以在编译、类加载、运行时被读取&#xff0c;并执行相应的处…

【分布式技术】分布式存储ceph之RGW接口

目录 1、对象存储概念 2、创建 RGW 接口 //在管理节点创建一个 RGW 守护进程 #创建成功后默认情况下会自动创建一系列用于 RGW 的存储池 #默认情况下 RGW 监听 7480 号端口 //开启 httphttps &#xff0c;更改监听端口 #更改监听端口 ​ //创建 RadosGW 账户 …

【Go学习】macOS+IDEA运行golang项目,报command-line-arguments,undefined

写在前面的话&#xff1a;idea如何配置golang&#xff0c;自行百度 问题1&#xff1a;通过idea的terminal执行go test报错 ✘ xxxxxmacdeMacBook-Pro-3  /Volumes/mac/.../LearnGoWithTests/hello  go test go: go.mod file not found in current directory or any parent …