Fluent Python

dict & set

2017-12-27  本文已影响9人  一块大番薯

新建 dict:

新建 dict (无序)

字典推导:

字典推导

常见方法

my_dict.setdefault(key, []).append(new_value)  # 只有一次键查询

if key not in my_dict:   # 第一次查询
  my_dict[key] = []      # 可能又一次查询
my_dict[key].append(new_value)  # 又一次查询

dict 变种

set

set 不可散列,frozenset 可散列。set 中元素要求可散列。
基于散列表,极快的查找速度,对 in 运算符优化
中缀运算符:|并、&交、-差

字典的散列表

散列表是一个稀疏数组(总有一些空白元素称为稀疏)
散列表单元称为表元(bucket),存放键和值的引用
Python 保证 1/3 表元是空的,快到这个阈值时散列表将会被复制到更大空间
要把一个对象放入散列表,首先要计算这个对象的散列值,即哈希值 hash()
CPython 一条实现细则:一个整型对象能被存入一个机器字中,那么它的散列值就是它本身
为让散列值能充当索引这角色,散列值之间应尽量分散开,即越是相似不等的对象,散列值相差越大
如果两个对象用 == 比较相等的,那么它们的散列值也应相等

散列表算法
散列表算法
dict 的实现及其特点
set 的实现及其特点

set 与 frozenset 都依赖于散列表,特点与 dict 类似
(1)散列表里存放的是元素的引用,就像字典里存放的只有键,散列表才存放值的引用
(2)set 元素必须可散列
(3)in 运算符很高效
(4)很耗内存
(5)元素次序取决于添加次序
(6)往 set 中添加新元素可能改变原有元素次序

杂谈

dict 优化目标:更好的实现对随机键的读取
JSON:瘦身版XML,从 JavaScript 发展而来,而 JavaScript 从 Python 里偷师使用了:(字面量句法),故除了 true、false、null 这几个值拼写有出入之外,其余 JSON 与 Python 是完全兼容的。dict 和 list 使 JSON 成为交换数据格式的主流。

上一篇 下一篇

猜你喜欢

热点阅读