python-list(列表)底层实现

1.python在创建空list时,会申请一个一定大小的内存区域,当满了后就会进行扩充(按比例进行扩充,比如:扩充成原内存区域大小的2倍的存储空间)。

2.python的列表采用分离式结构的顺序表,列表对象里只保存与整个表有关的信息:容量、元素的个数以及元素存储区的地址,即元素数据和列表的头信息分开存储。当进行扩充时,可在不改变列表对象的前提下对其数据存储区域进行扩充,只需将链接地址更新一下(表头不变),也就是说所有使用这个列表的地方都不用修改。(因此扩充是对元素存储区进行扩充)
因为列表它的头信息是和元素分开存储的,所以当元素改变时,其列表里的链接地址(id)依然不变(依然指向元素存储地址)。
因为存储的是地址,所以元素可以是任意类型啦。

3.python的列表采用指针,元素有位置下标,连续的存储空间,以偏移量计算取得元素,不必遍历所有元素。

目前的理解就这些,有新的理解再来更新。
大家有不同的理解欢迎来评论区留言,谢谢。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值