类与对象深度问题

__new__方法

def new(cls)#创建一个类对象,自动运行,当期运行时如果没有创造对象并且返回则不会运行__init__方法,因为__init__方法是只有对象被创建时才会自动调用。一般init会自动调用是因为对象被自动创建了,所有类的父类object有这个功能,当当你运行了__new__之后object不会在运行,所以假如__new__中没有创建对象则__init__不会运行。
一般在new方法最后加一行:
return object.new(cls)#通过从object方法中调用new来创建对象。
new方法也可以直接写在程序里:
li=list.new(list,“abc”)
print(li)
输出【】
new创建列表时不会写入所以’abc’没有写入,但假如创建元组则会写入。

  • __new__通常不需要手动定义,一般在元类编辑中使用,控制类的生成过程。
  • __new__第一个被执行,然后执行__ini__t绑定实力变量。
  • __new__必须有返回值,返回值是该类的实例,他会被__init__函数接收,通常叫做self变量。

内存

__dict__的实质时动态绑定属性
p1.dict[key]=value,可以添加,操作类似字典,引用快,占用空间大。
__slots__能创建只读,使用的内存少,引用慢

with的运行原理

with open(文件位置)as 命名
可以直接打开文件,open(文件位置)可以换成函数名,但里面必须有def __enter__和def exit,因为with打开文件后不需要关闭的实质就是with可以运行这两个函数。
装饰器@contextlib.contextmanager等于加入了enter和exit。

一些函数

a.gt(b)a是否大于b
from functools import total_ordering
可以导入@total_orfering装饰器,这样你的函数的结果是可比较的就可以比较,不然实例与实例的比较其实就是类与类的比较。

你可能感兴趣的:(类与对象深度问题)