python 编程模型

数据模型(译)

image.png

1 对象(object)、类型(type)和值(value)

python中所有的数据都是通过对象(object)或者对象之间的关系来表示

每个对象(object)都有ID、类型(type)和数值(value)

一旦对象创建,它的ID便固定不变,可以理解成对象存放在内存中的地址;is操作就是比较两个对象的ID,而id()函数则是返回对象ID的整数表达式

对象的类型(type)决定了对象的行为,以及决定对象可能的值(value);type()函数返回对象的类型(type本身也是对象);类似于ID,对象的类型一般情况下也是不可变的

部分对象的值(value)是可变的,我们称之为可变类型(mutable);部分对象的值是不可变的,我们称这为不可变类型(immutable);当一个不可变容器(如tuple)包含可变类型的对象引用,虽然引用对象的值可以改变,但我们依然认为此容器的值不是可变的,因为容器本身包含的对象不可变,所以严格来讲,不可变类型并不意味着数值(value)不可更改。对象是否可变由类型决定,比如数字(numbers)、字符串(strings)和元组(tuples)是不可变的;字典(dictionaries)和列表(lists)是可变的

对象从不显示地销毁,当没有引用指向这些对象时,它们就可能被回收(GC)

注意,try...except语句会使对象保持存活

有些对象指向外部资源,如打开的文件或窗口;当对象被回归时,资源也一并释放。然而由于回收机制无法确定触发,所以类似的对象提供了显示的方式来释放外部资源,通常是close()方法。程序建议使用try...finally或者with语句来显示关闭

2 特殊方法

类可以通过定义具有特殊名称的方法来实现由特殊语法调用的某些操作,这是python的运算符重载方法,允许类根据语言运算符定义自己的行为

例如,如果一个类定义了__getitem__()的方法,并且x是该类的一个实例,那么x[i]大致相当于type(x).__getitem()__(x, i)

将特殊方法设置为None,意味着相关操作不可用;比如,将类的__iter()__方法设置为None,类将无法迭代,因此调用iter()方法时会抛出类型错误(TypeError)的异常

2.1 基本定制

object.__new__(cls[, ...])

创建类的实例,__new__()是静态方法,它将请求实例的类作为第一个参数,其余参数传递给对象构造函数,__new__()的返回值应该是新的对象实例(通常是cls的实例)

典型的实现__new__(),是使用适当的参数调用超类的方法,然后在返回之前根据需要,修改新创建的类的实例,super().__new__(cls[, ...])

如果__new__()返回cls的实例,那么实例的__init__()方法将被调用,如__init__(self [, ...]),其中self 代表新实例,其余的参数与传入__new__()方法的参数相同

如果__new__()没有返回类的实例,那么__init__()方法将不会调用

__new__()意在允许不可变类型(如数字、字符 串、元组)的子类自定义实例的创建;另外,也可以创建自定义的元类(metaclass)来定制类的创建

object.__init__(self, [...])

在实例被创建(即__new__())后,尚未返回给调用者之前调用,参数与传递给类的构造器表达式一致。如果基类有__init__()方法,子类的__init__()方法,如果存在的话,必须显示调用来保证实例的基类实例化操作,如super().__init__([args...])

因为__new__()__init__()共同完成对象的创建(new用来创建,init用来初始化),所以__init__()不允许非空值返回,不然的话会在运行时抛出类型错误异常

object.__del__(self)

在实例将要销毁时调用

object.__repr__(self)

通过repr()内置函数调用,用来获取对象的机器表达式;如果可能的话,这应该看起来像一个有效的python表达式,可用于重新创建具有相同值的对象;如果无法做到这一点,则应返回形式上的字符串

object.__str__(self)

通过str(),format(),print()方法调用,计算对象的可打印字符串

object.__repr__()的不同在于,__str__()不要求返回有效的python表达式,即可以使用更方便更简洁的表示方式

object.__bytes__(self)

通过bytes调用,计算对象的字节码

object.__bool__(self)

返回True或False,如果此方法未定义,__len__()被调用,非0意味着True;如果2个方法都未定义,则认定返回值为True

2.2 基本属性访问

object.__getattr__(self, name)

当调用__getattribute__()方法抛出AttributeError异常,或者__get__()方法抛出AttributeError异常时,__getattr__()才被调用,可以返回某个值,异或同样抛出异常

object.__getattrbute__(self, name)

访问实例的属性时无条件调用

为了避免无限递归,方法内部在访问对象的属性时,应始终使用类方法,而不是A.a的形式

object.__setattr__(self, name, value)

属性赋值时调用

object.__delattr__(self, name)

删除对象的属性

object.__get__(self, instance, owner)

在获取类(owner)的属性,或者类的实例(instance)的属性时调用

object.__set__(self, instance, value)

将实例的属性设置为新值

object.__delete__(self, instance)

删除实例的属性

2.3 自定义类创建

object.__init_subclass__(cls)

当一个类继承自另一个类时,另一个类的__init_subclass__()方法都将被调用

class Philosopher:def __init_subclass__(cls, default_name, **kwargs): super().__init_subclass__(**kwargs) cls.default_name = default_name class AustralianPhilosopher(Philosopher, default_name="Bruce"): pass 

默认情况下,object.__init_subclass__()无任何操作,但是被调用时,如果有传入参数,会抛出异常

元类(metaclass)

默认情况下,类对象通过type()函数创建,type(name, bases, namespace)

类对象的创建过程,可以通过传递metaclass关键字属性,或者继承自另一个拥有此参数的类

定义类对象时,会执行如下操作:

  • MRO entries are resolved(还不清楚具体含义)
    • 如果基类不是type,会搜索__mro_entries__方法;如果发现了,通过original bases tuple调用;该方法必须返回类的元组,当然可以为空
  • the appropriate metaclass is determined
    • 如果没有明确指定metaclass,则使用type
    • 如果指定了metaclass,且不是type的实例,那么直接使用
    • 如果指定了type的实例作为metaclass,那么将追溯到顶层的metaclass并使用
  • the class namespace is prepared
    • 如果metaclass有__prepare__属性,那么namespace = metaclass.__preprare__(name, bases, **kwargs)
    • 如果没有__prepare__属性,类的命名空间将被初始化为空的有序映射
  • the class body is executed
  • the class object is created
    • 通过执行类主体填充命名空间后,调用metaclass(name, bases, namespace, **kwargs)方法来创建类对象,额外的关键字参数与__prepare__相同

元类事例

class OrderedClass(type):  @classmethod def __prepare__(metacls, name, bases, **kwds): return collections.OrderedDict() def __new__(cls, name, bases, namespace, **kwds): result = type.__new__(cls, name, bases, dict(namespace)) result.members = tuple(namespace) return result class A(metaclass=OrderedClass): def one(self): pass def two(self): pass def three(self): pass def four(self): pass >>> A.members ('__module__', 'one', 'two', 'three', 'four') 

2.4 模拟可调用对象

object.__call__(self [, args...])

使实例可以像函数一样调用,假设定义方法x(arg1, arg2, ...),相当于调用x._call_(arg1, arg2, ...)`

2.5 模拟容器类型

object.__len__(self)

len()方法的实现,返回对象的长度

object.__getitem__(self, key)

self[key]的实现,对于序列,key必须为整数或切片对象

object.__missing__(self, key)

对字典类型数据,调用self[key]且key不在字典中时触发

object.__setitem__(self, key, value)

对self[key]赋值,注意只适用于key对应的值可以改变,或者可以追加新key

object.__delitem__(self, key)

删除self[key]

object.__iter__(self)

当容器需要迭代器时,调用此方法,返回一个新的迭代器对象

如果是映射类型,应当迭代容器的所有键

object.__reversed__(self)

reversed()方法的实现,返回一个新的迭代器,以倒序形式迭代容器中的元素

object.__contain__(self, item)

成员检测时调用,返回True或False

对于映射类型,只考虑键是否包含,而非值

2.6 with语句

上下文管理器是在执行with语句时定义要建立的运行时上下文的对象

上下文管理器处理对代码执行所需的运行时上下文的入口和出口

上下文管理器的典型应用包括,保存或恢复各种全局状态、锁定和解锁资源、打开关闭文件等

object.__enter__(self)

与对象相关的运行时上下文入口,with语句将方法的返回值绑定到as子句指定的目标

object.__exit__(self, exc_type, exc_value, traceback)

与对象相关的运行时上下文出口,如果退出时无异常,三个参数都为None

如果有异常出现,此方法希望禁止异常抛出,从而返回一个真正的值;否则异常将在退出此方法时正常处理



转载于:https://www.cnblogs.com/aibabel/p/11030976.html

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

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

相关文章

MySQL实战练习

在测试Django的数据库同步时,经常会出现需要Drop掉MySql数据库表情况。单独开发了一个MySQL删除脚本。 其中涉及到动态语法与MySQL的数据字典概念。 CREATE DEFINER Productlocalhost PROCEDURE ClearTables( IN Confirm BOOLEAN ) DETERMINISTIC MODIFIES SQL DAT…

R中统计假设检验总结(一)

先PS一个:考虑到这次的题目本身的特点 尝试下把说明性内容都直接作为备注写在语句中 另外用于说明的部分例子参考了我的教授Guy Yollin在Financial Data Analysis and Modeling with R这门课课件上的例子 部分参考了相关package的帮助文档中的例子 下面正题- 戌 >…

linux中如何快速进入某个目录

http://blog.csdn.net/qinglu000/article/details/17247283 1. 如果偶尔进的话可用tab键加速目录输入速度。 2. 如果经常进某个目录可设置环境变量例如$DIRPATH/usr/bin,通过cd $DIRPATH的方式进入。 3. 更简单可以通过alias 命令注册一个快捷命令如alias uucd /us…

事务的四大特性和隔离级别

1.事务的四大特性(ACID):指数据库事务正确执行的四个基本要素的缩写。包含:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability&#xff09…

改造MUC实现Openfire群

我的Openfire群实现思路: 1、群和群成员,要保存到表中。 2、拉取群列表和群成员列表,均从DB中查询返回。 3、抛弃老外的“进房间,要发Presence ”。只要此人一上线,就模似一个Presence进行joinRoom,进入他的…

如何在Windows环境下的VS中安装使用Google Protobuf完成SOCKET通信

http://blog.csdn.net/whuancai/article/details/11994341 如何在Windows环境下的VS中安装使用Google Protobuf完成SOCKET通信 原文出自:http://blog.csdn.net/monkey_d_meng/article/details/5894910 尊重作者:MONKEY_D_MENG 最近一段时间,由…

14 Scroll 滚动搜索

Scroll的用法:第一次搜的时候,要指定 快照保留时间1min,分页的大小:2条/页;对于第一次搜索,ES会返回一个这个scroll的id;下次再搜的时候,就带着这个scrollid去搜就行了,不…

解决IE6透明PNG图片的代码

使用方法1.下载DD_belatedPNG.js文件&#xff08;官方网站&#xff1a;http://www.dillerdesign.com/experiment/DD_belatedPNG/&#xff09;. 2.在网页中head区引用,如下:<!--[if IE 6]><script src"DD_belatedPNG.js" mce_src"DD_belatedPNG.js"…

LVS+Keepalived负载均衡方式总结

1、负载均衡器、服务器集群直连方式&#xff08;lb_kind DR&#xff09;http://network.51cto.com/art/201006/206831.htmhttp://www.myhack58.com/Article/sort099/sort0102/2012/35640_4.htm负载均衡器最简洁安装可以直接#yum ipvsadm keepalived根据51cto.com网站知道要分别…

VS2008中使用JSONCPP方法小结

http://sourceforge.net/projects/jsoncpp/?sourcetyp_redirect C要使用JSON来解析数据&#xff0c;一般采用jsoncpp. 下载jsoncpp后&#xff0c;按ReadMe文档的说法是要先安装的&#xff0c;但是安装比较麻烦。然而事实上&#xff0c;我们并不需要安装&#xff0c;就可以直接…

SQL条件语句(IF, CASE WHEN, IF NULL)

1.IF 表达式&#xff1a;IF( expr1 , expr2 , expr3 ) expr1条件&#xff0c;条件为true&#xff0c;则值是expr2 &#xff0c;false&#xff0c;值就是expr3 SELECT o.id,u.account,catagory.name,orderTime,detail.amount,periodtime,if(direction0,看涨,看跌) directionNam…

Forensic Challenge 9 - Mobile Malware

使用智能手机的人越来越多&#xff0c;对智能手机的安全研究也慢慢开始成为重点。The honey project有一个Mobile malware的挑战赛&#xff0c; 带你走进Mobile Malwares的世界。参见&#xff1a; Forensic Challenge 9 - "Mobile Malware" 样本&#xff1a; fc9fil…

如何在Windows下编译OpenSSL

OpenSSL是一个开源的第三方库&#xff0c;它实现了SSL&#xff08;Secure SocketLayer&#xff09;和TLS&#xff08;Transport Layer Security&#xff09;协议&#xff0c;被广泛企业应用所采用。对于一般的开发人员而言&#xff0c;在 http://slproweb.com/products/Win32Op…

《团队名称》第八次团队作业:Alpha冲刺day5

项目内容这个作业属于哪个课程2016计算机科学与工程学院软件工程(西北师范大学)这个作业的要求在哪里实验十二 团队作业8—软件测试与ALPHA冲刺团队名称快活帮作业学习目标 &#xff08;1&#xff09;掌握软件测试基础技术。 &#xff08;2&#xff09;学习迭代式增量软件开发过…

(转)C# 把我所积累的类库全部分享给博友(附件已经上传)

http://files.cnblogs.com/LsGW/Common.zip转载于:https://www.cnblogs.com/meetrice/archive/2012/01/02/2310428.html

Oracle的resetlogs机制浅析

alter database open resetlogs 这个命令我想大家都很熟悉了&#xff0c;那有没有想过这个resetlogs选项为什么要用&#xff1f;什么时候用&#xff1f;它的原理机制是什么&#xff1f;他都起哪些作用&#xff1f;我们都知道数据在启动时候是要做一致性检查的&#xff0c;oracl…

前端的小图标获取

搜索iconfont&#xff0c;里面有很多图标&#xff0c;鼠标移到想要的图标上&#xff0c;然后点击一个类似购物车的图标&#xff0c;然后添加到项目&#xff0c;下载到本地&#xff0c;有一个使用指南的html&#xff0c;然后参照上面的改就好。 把下载好的.css和.eot文件拖到css…

LINQ学习笔记(9) LINQ to Objects---查询内存中对象的集合

从这一篇开始要总结的是LINQ在实际中的应用&#xff0c;首先要总结的是LINQ to Objects&#xff0c;也就是LINQ与程序对象的配合使用。 其中程序对象集合最典型就是与数组的配合使用,如下示例&#xff1a; 1 class Program 2 { 3 static void Main(string[] args) …

$JavaScript(3)

41、渐进增强和优雅降级 渐进增强 &#xff1a;针对低版本浏览器进行构建页面&#xff0c;保证最基本的功能&#xff0c;然后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。 优雅降级 &#xff1a;一开始就构建完整的功能&#xff0c;然后再针对低版本浏…

[恢]hdu 1846

2011-12-23 06:07:41 地址&#xff1a;http://acm.hdu.edu.cn/showproblem.php?pid1846 题意&#xff1a;中文。 mark&#xff1a;考虑n%(m1)是否为0。 代码&#xff1a; # include <stdio.h>int main (){int T, n, m ; scanf ("%d", &T) ;while (T--)…