博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python的字典(dict)的键值对存储规则
阅读量:5296 次
发布时间:2019-06-14

本文共 649 字,大约阅读时间需要 2 分钟。

一.字典中键值对的存储方式

再理解键值对的存储原理之前,首先我们先来了解一下什么是Hash:

 

散列函数(或散列算法,又称哈希函数)是一种从任何一种数据中创建小的数字‘‘指纹’’的方法。散列函数

把消息或数据压缩成摘要,使得数据量变小,将数据的格式固定下来。该函数将数据打乱混合,重新创建一个叫做散列值的指纹,散列值通常用来代表一个短的随机字母和数字组成的字符串。好的散列函数再输入域很少出现散列冲突。再散列表和数据处理中,不抑制冲突来区别数据,会使得数据库记录更难找到。

 

首先看下图:

 

如图:

在创建字典时,python调用内部的散列函数,将键(key)作为参数进行转换,得到一个唯一的地址(这也解释了为什么给相同的键赋值会直接覆盖的原因,因为相同的键转换后的地址是一样的),然后将值(Value)存放到该地址中。

 

因此我们可以推导出,对于python来说,键(key)必须是可哈希(即可以调用散列函数)的,换句话说就是要可以通过调用散列函数计算出唯一地址的。

 

所以:列表,字典,集合这些可变数据类型都不能作为键(key)来使用。

那元组呢?虽然元组是不可变的,但如果元组里面的元素有不可变数据类型时,也不可作为字典中的键(key),即必须对元组做出限制。

 

PS:另外要注意的是,python的哈希算法对相同的值计算得到的结果是一样,也就是123和123.0的值相同,他们被认为是相同的键(key)

 

转载于:https://www.cnblogs.com/HZY258/p/8342321.html

你可能感兴趣的文章
修改linux远程22端口,linux修改ssh远程端口22
查看>>
Linux系统的创始者,组图:Linux之父的办公室首度曝光
查看>>
ubuntu18.04运行linux,如何在 Ubuntu 18.04 上安装 Postman
查看>>
关于linux的环境变量设置,linux环境变量设置
查看>>
linux查看内存和硬盘,Linux 查看内存,CPU及硬盘大小的步骤
查看>>
linux下tcp ip的配置,linux下配置TCP/IP的几种方法
查看>>
linux纯文本上网,Lynx 2.8.8rel.1 发布,纯文本网页浏览器
查看>>
shell命令下载文件linux,Linux基础:如何使用Wget在Shell上下载文件
查看>>
桂林航天工业学院c语言实验报告,桂林航天工业学院:C语言自考复习宝典
查看>>
pLC中C语言的运算符是什么,c语言中的“?:”是什么运算符
查看>>
android 耳机检测,检测耳机是否已插入Android设备。
查看>>
android开发常用app有哪些,android 开发之app都可以进行哪些优化
查看>>
android按钮显示文字,android 按钮的文字显示不全
查看>>
c语言有较强的网络操作功能,《C语言程序设计》第1章 C语言概述练习题答案
查看>>
android代码下拉刷新页面,Android下拉刷新的实现
查看>>
android 的gridview,android中的GridView和GridLayout
查看>>
唤醒时间过长 Android,关于android:功耗问题之过多唤醒源-wakeups
查看>>
android开发影片类型选择,如何选择要在网路,Android和iOS上播放的影片格式?
查看>>
html 编辑器里自动换行,WordPress中百度编辑器ueditor前台代码语言无法自动换行解决办法...
查看>>
HTML页面的主体标签是什么,html网页的主体标签是什么
查看>>