python字典的实现原理_Python字典的实现原理
以下是自己的学习记录,算是一个总结。
接下来会依次对下面问题做一个解答:
1. Python的dict和set为什么是无序的?
2. 为什么不是所有的python对象都可以用作dict的键和set中的元素
要弄懂上面的问题,我们首先要了解Python内部是如何实现dict和set类型的。我们先来看看dict的内部结构,dict其实本质上是一个散列表(散列表即总有空白元素的数组,Python会保证至少有三分之一的数组元素是空的),dict的每个键都占用一个表元,而一个表元中又分为两个部分,分别是对键的引用和对值的引用。当我们存放一个对象的时候,首先会要计算这个元素的散列值,python中使用hash()方法来实现的,这也就回答了第二个问题,因为不是所有的python对象都可以使用hash来获取散列值,获取不到散列值也就不可能存放到dict中,所以只有可hash的对象才能够作为dict的键。值得注意的是内置的hash方法可以用于所有的内置类型对象的,所有用户自定义的对象默认都是可以作为键的,因为自定义对象的散列值是通过id()来获取的。例如:
class T(object):
pass
t = T()
print(id(t))
d = {t: 1}
print(d)
### 2133693018240
### {<__main__.t object at>: 1}
现在假设我们已经获取到了元素的散列值,接下来就该计算应当存放位置了,将散列值对数组长度进行取余,得到的结果就是存放位置的索引了。但是不同的key可能会得到相同的散列值,也就是哈希冲突的问题,python内部是使用开放寻址的方法来解决的,开放寻址法就不在此详细说了。关于为什么dict是无序的,这个是因为python内部会保证散列表至少有三分之一的位置为空,当我们增加元素的时候,python有可能会对散列表进行扩容,具体操作就是重新开辟一块更大的空间,将原有的元素添加到新表里面,这个过程中可能又会发生新的散列冲突,导致新的散列表中的键的次序发生变化。当然呢如果想要保存顺序也可以使用OrderedDict来处理
dict操作的时间复杂度:
操作
操作说明
时间复杂度copy
复制
O(n)
get(value)
获取
O(1)
set(value)
修改
O(1)
delete(value)
删除
O(1)
search(in)
字典搜索
O(1)
iterration
字典迭代
O(n)
set集合和dict一样也是基于散列表的,只是他的表元只包含值的引用而没有对键的引用,其他的和dict基本上是一致的,所以在此就不再多说了。
python字典的实现原理_Python字典的实现原理相关推荐
- python字典如何删除数据库_Python 字典删除元素clear、pop、popitem
同其它python内建数据类型一样,字典dict也是有一些实用的操作方法.这里我们要说的是字典删除方法:clear().pop()和popitem(),这三种方法的作用不同,操作方法及返回值都不相同. ...
- python字典里存字符_Python字典和字符串的学习
学习Python的字典还是和oc的字典进行对比学习,首先我们来创建一个字典.根据oc中字典一样,字典是无序的,根据键来进行取值. oc: oc中的字典分为可变字典和不可变字典,在对字典进行增,删的时候 ...
- python字典添加主键_python 字典相关操作
Python 中的一种数据结构 -- 字典( Dictionary )的使用方法总结. 一. dictionary 数据类型的结构是: {key1:value1, key2:value2, ...} ...
- python字典与json转换_python字典与json转换的方法总结
在python中json分别由列表和字典组成,本文主要介绍python中字典与json相互转换的方法.使用json.dumps可以把字典转成json字符串.使用json.loads可以把json字符串 ...
- python字典怎么添加值_python字典中如何添加键值对
添加键值对 首先定义一个空字典 1 >>> dic={} 直接对字典中不存在的key进行赋值来添加 1 2 3 >>> dic['name']='zhangsan' ...
- python字典统计单词个数_python字典统计单词个数
python 字典中的词频统计之后 如何将频数大于一个比如a出现了10次,b15次,c20次,d25次,CSS布局HTML小编今天和大家分享频数大于14的词的个数,应该v={} for i in di ...
- python字典操作的方法_python 字典操作方法详解
python 字典操作方法详解 一.总结 一句话总结: 字典就是键值对映射 ,像js和php中的键值对数组:{'name':'jamnes','age':'32'} 1.python字典的增删改查? ...
- python字典键值唯一_python字典操作详解
python字典是一个无序.以键值对存储的数据类型,数据关联性强.唯一一个映射数据类型.键:必须是可哈希(不可变的数据类型:字符串.数字.元组.bool)值,并且是唯一的 None: none 是一个 ...
- python字典按键值排序_Python字典『键 值』排序
假设有一个字符串,然后想要查一下每个字母出现了多少次,可以通过字典来实现,实现方法? 用了get方法,来编写一下histogram这个函数,去掉那些if语句,更简洁一下: def histogram( ...
最新文章
- ios pusher使用_如何使用JavaScript和Pusher实时更新用户状态
- windows2008C盘清理
- python 编译器pyc_有没有办法知道哪个Python版本.pyc文件被编译?
- c语言宿舍管理设计报告,C语言课程设计—学生宿舍管理系统设计报告.doc
- SVN:retrieval of mergeinfo unsupported by
- Python 基础 —— re:正则表达
- sudoku me_Java Sudoku解算器程序
- (译)响应式图片— srcset 和 sizes 属性
- 工商银行c语言笔试题,【中国工商银行研发软件笔试试题及答案】 - 面试网
- 谢耳朵用的MIT人工智能情绪探测器,你也可以拥有
- Qt tableWidget导入\导出Excel表格
- MySQL增删改查及备份恢复
- 薇娅,李佳琦都点赞的淘宝双11直播系统,是如何打造的?
- 服务器必备工具软件推荐
- LEETCODE838java
- leetcode总结
- CPU、GPU、TPU的原理简述及其区别
- SSCNet环境搭建
- 如何在 JavaScript 中检查数字是正数还是负数
- 【云原生 | 从零开始学Docker】一、Docker的安装,启动以及工作原理
热门文章
- 登顶CLUE榜单,腾讯云小微与腾讯AI Lab联合团队提出基于知识的中文预训练模型...
- 46 万奖金等你拿 | 微众银行第二届金融科技高校技术大赛报名中
- 科学家都解决不了的5个“简单”算法,你不来看看?
- 圆圈中最后剩下的数字
- K-近邻算法之案例:鸢尾花种类预测—流程实现
- 计算机操作系统第四版习题答案 第一章简答题
- 复习计算机网络基础 day8--传输层
- 网络工程师_想要记录下来的一些题_2
- 基于交换技术的网络中,全双工主要运行在?( 内有答案与详解)
- ACMNO.20 C语言-插入队列 已有一个已排好的9个元素的数组,今输入一个数要求按原来排序的规律将它插入数组中。 输入 第一行,原始数列。 第二行,需要插入的数字。