python进阶(24)Python字典的底层原理以及字典效率

本文探讨了Python字典从3.5版本到3.6版本的底层原理变化,解释了字典的有序性及效率提升。在Python 3.5之前,字典基于二维数组实现,而3.6以后,采用一维数组和二维数组结合的方式,减少了内存占用并保证了插入顺序。此外,文章还总结了字典的使用注意事项,如键必须可散列,以及字典遍历与修改的限制。
摘要由CSDN通过智能技术生成

前言

  • 问题1:python中的字典到底是有序还是无序
  • 问题2:python中字典的效率如何

python字典底层原理

  在Python 3.5以前,字典是不能保证顺序的,键值对A先插入字典,键值对B后插入字典,但是当你打印字典的Keys列表时,你会发现B可能在A的前面。

  但是从Python 3.6开始,字典是变成有顺序的了。你先插入键值对A,后插入键值对B,那么当你打印Keys列表的时候,你就会发现B一定在A的后面。

  不仅如此,从Python 3.6开始,下面的三种遍历操作,效率要高于Python 3.5之前:

for key in dict1
 
for value in dict1.values()
 
for key, value in dict1.items()

从Python 3.6开始,字典占用内存空间的大小,是字典里面键值对的个数,只有原来的30%~95%。
Python 3.6到底对字典做了什么优化呢?为了说明这个问题,我们需要先来说一说,在Python 3.5之前,字典的底层原理。

python3.5之前字典的底层原理

当我们初始化一个空字典的时候,CPython的底层会初始化一个二维数组,这个数组有8行,3列,如下面的示意图所示:

my_dict = {}
 
'''
此时的内存示意图
[
  [---, ---, ---],
  [---, ---, ---],
  [---, ---, ---],
  [---, ---, ---],
  [---, ---, ---],
  [---, ---, ---],
  [---, ---, ---],
  [---, ---, ---]
]
'''

现在,我们往字典里面添加一个数据:

my_dict['name'] = 'jkc&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值