网站首页 > 基础教程 正文
字典
字典有序还是无序
初次接触python的时候,那时候用的python版本是2.7, 字典是无序的,就是说你update一个字典,新加的键值对不一定出现在字典的末尾,而是有可能出现在其他地方,popitem弹出键值对的时候也不是按照先进后出的原则从列表的末尾弹出,而是弹出任意一个键值对
现在从python3.7后,字典正式成为有序的,举例
python2
python3.7
原因:
之前创建字典保存需要以下3个值来保存一个键值对:
hash(key),
key的内存地址,
value的内存地址 因此底层是一个二维数组,各个键值对存放的位置由hash(key)取余后得出,因此存放位置不是按顺序的。 例如:
python3.7之后,字典底层是2个数组:一个为一维数组,存放hash(key)取余后的值作为数组的索引,对应索引位置存放键值对在二维数组的索引位置。因此二维数组是一个有序的数组。 例如:
所以你看索引0对应着字典的第一个{"timmy":red}
我们也可以看下字典对象的源码,例如popitem的实现
有序了之后就方便我们存储数据之后,进行一些后续的操作和判断,比如之前的自动化项目中,要执行的功能模块和模块的一些配置信息,存储为字典类型时,就能轻易知道执行模块的顺序信息和一些其他要求,而不是把模块,和模块对应的配置信息,分别存放为两个列表来进行一一对应, 毕竟字典的性能要比列表更高效。
猜你喜欢
- 2025-01-07 Python从入门到放弃-详解列表、元组和字典
- 2025-01-07 python 中字典如何进行复制
- 2025-01-07 python入门023:字典嵌套
- 2025-01-07 掌握Python字典的12个例子
- 2025-01-07 使用Python 获取多级字典(Json)格式所有Key、Value
- 2025-01-07 简单学Python——字典的操作1(增加、更改和删除字典元素)
- 2025-01-07 Python之容器拾遗:Python就是包裹在一堆语法糖中的字典
- 2025-01-07 如何在 Python 中以列表形式返回字典的键
- 2025-01-07 解锁Python字典合并:多种方法解析
- 2025-01-07 Python 动手练:字典
- 05-22Linux cron任务计划
- 05-22测试人员如何在linux服务器中查询mysql日志?
- 05-22Nginx命令最全详解(29个最常用命令)
- 05-22初识自动化网络编排器NSO,轻松配置复杂的多厂商网络
- 05-22Nacos在企业生产中如何使用集群环境?
- 05-22如何从 MySQL 错误日志中排查数据库故障
- 05-22Linux面试最高频的5个基本问题
- 05-22linux网卡混杂模式
- 最近发表
- 标签列表
-
- jsp (69)
- gitpush (78)
- gitreset (66)
- python字典 (67)
- dockercp (63)
- gitclone命令 (63)
- dockersave (62)
- linux命令大全 (65)
- pythonif (86)
- location.href (69)
- dockerexec (65)
- tail-f (79)
- deletesql (62)
- c++模板 (62)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- console.table (62)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)