400 028 6601

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

重要数据结构——list,tuple,set,dict

基本特性和创建对比:

在阜平等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都做网站、成都网站设计 网站设计制作按需设计网站,公司网站建设,企业网站建设,成都品牌网站建设,全网整合营销推广,外贸网站制作,阜平网站建设费用合理。

列表:

可变的,可重复的,有序的 ,线性的
列表个体称为元素,元素可以是任一对象
一定均匀分配每个元素的内存存储空间,因为它靠偏移量来搜索元素,列表中存放的都是数据的内存地址,而不是数据,真正的数据存放在其他地方。

元组:
不可变,可重复的,有序的,只读的(没有增删改查)
元组个体称为元素,元素可以是任一对象
对于不需要修改的序列,我们最好将其定义为元组。(因为元组的结构相比列表更简单,所以它比列表更加节省内存空间)

集合(set):

可变的,无序的,不可重复的
有序才是线性的,无序不是线性的。set集合的元素是不可以索引的,因为set是无序的。但是set是可以迭代,这就是为什么可索引的一定是可迭代的,但是可迭代的不一定是可索引的。
set的元素必须可以hash的。
只要是不可变类型的数据结构都是可hash的(hashable),具体如下:
数值型int、float、complex
布尔型True、False
字符串string、bytes
tuple
None:空值也是可以hash的,因为它是一个常量,不可变。
为什么说可变类型的数据结构不可hash呢?因为只要数据一变,hash后的key也会跟着变。这对以hash值为索引依据的set集合而言是不可接受的,需要频繁的维护hash表。得不偿失。

字典:

可变的,无序的,key值不重复
字典是key:value键值对的数据集合
创建字典的时候一定要注意,key一定要是可hash的数据结构,否者会抛出TypeError的异常。

字典元素的访问:
d[key]:返回key对应的值value,key如果不存在则抛出KeyError异常
get(key[, default]):返回key对应的值value,但是如果key不存在则返回缺省值,如果没有设置缺省值就返回None
setdefault(key[, default]):如果key存在,返回key对应的值value。如果key不存在,则添加key:value对,value为default,并返回default,如果default没有设置,缺省为None,一定要注意setdefault不能够修改key的value,当key存在时,它只是返回key的value,并不会修改key的值。


增删改查对比:
list:

set:

dict:


本文名称:重要数据结构——list,tuple,set,dict
文章路径:http://mbwzsj.com/article/pecsse.html

其他资讯

让你的专属顾问为你服务