set
from collections.abc import Mapping, MutableMapping
# dict 属于 Mapping 类型
my_dict = {}
print(isinstance(my_dict, MutableMapping))
# True
s1 = set('abc')
s2 = set('cde')
s3 = set('ef')
s1.update(s2)
print(s1) # {'a', 'b', 'd', 'c', 'e'}
print(s1.difference(s3)) # {'a', 'd', 'c', 'b'}
| 并集
& 交集
- 差集
frozenset
fs = frozenset('abcde')
print(fs)
# frozenset({'a', 'b', 'c', 'e', 'd'})
frozenset可以作为dict的key
dict和set的实现原理
dict查找的性能远远大于list
list中查找元素的速度随着list的元素数量增加而增加
dict中查找元素的速度不会随着dict的元素数量增加而增加
dict的key和set的值必须可hash(不可变对象都是可hash的,例如string、frozenset、tuple),list不能作为dict的key
dict的内存花销大
dict的存储顺序和元素添加顺序有关
对象引用、可变性和垃圾回收
python的变量实质上是一个指针,指针本身的大小是固定的
del和垃圾回收
python中垃圾回收的算法是采用引用计数
del是将引用计数减一
__del__魔法函数
元类编程
# __getattr__ 在查找不到属性的时候调用
# __getattribute__ 在查找属性的时候调用
属性描述符
一个类实现了下面三个魔法函数中至少一个,这个类就是一个属性描述符
__get__
__set__
__delete__
数据属性描述符
非数据属性描述符:只实现了__get__魔法函数
__new__和__init__的区别
__new__:第一个参数是cls(类)
__init__:第一个参数是self,
__init__是在__new__之后调用的。
__new__是用来控制对象的生成过程,在对象生成之前。
__init__是用来生成对象的。
如果__new__方法不返回对象,则不会调用__init__函数。
元类
元类是创建类的类:type