python中字典是如何在CPython中实现的?
CPython的字典实现为可调整大小的哈希表。与B-树相比,这在大多数情况下为查找(目前最常见的操作)提供了更好的性能,并且实现更简单。
字典的工作方式是使用 hash()
内置函数计算字典中存储的每个键的hash代码。hash代码根据键和每个进程的种子而变化很大;例如,”Python” 的hash值为-539294296,而”python”(一个按位不同的字符串)的hash值为1142331976。然后,hash代码用于计算内部数组中将存储该值的位置。假设您存储的键都具有不同的hash值,这意味着字典需要恒定的时间 — O(1),用Big-O表示法 — 来检索一个键。
来源:PY学习网:原文地址:https://www.py.cn/article.html