python列表底层原理

Python 列表(list)是 Python 中非常常用的数据结构之一。它们的底层实现基于动态数组,具体来说,是一个可以动态调整大小的数组。这使得列表在操作和使用上非常灵活。以下是 Python 列表底层实现的主要原理:

动态数组

Python 列表是通过动态数组实现的,这意味着列表在需要时可以自动调整其大小。初始分配一个固定大小的数组,当元素数量超过当前容量时,会分配一个更大的新数组,并将旧数组的元素复制到新数组中。

动态调整大小

当列表需要扩展时,Python 不只是简单地增加一个新元素,而是通常会按一定比例扩展列表的容量。常见的增长策略是将当前容量扩大为原来的 1.125 倍到 2 倍之间(具体策略取决于 Python 的实现版本)。这避免了每次添加新元素时都需要重新分配和复制数组,从而提高了性能。

内存分配策略

Python 使用分配器管理内存,以减少因频繁分配和释放内存导致的碎片化。当需要扩展列表容量时,会预先分配更多的空间,以容纳未来可能添加的元素。这种策略被称为“缓冲增长”,在减少内存操作次数的同时,提供了较好的性能。

时间复杂度

  • 索引和更新操作:由于列表底层是数组,这些操作的时间复杂度为 (O(1))。
  • 添加元素:如果没有达到当前容量,添加操作(append)的时间复杂度为 (O(1))。如果需要扩展容量,时间复杂度为摊销的 (O(1))。
  • 删除元素:删除操作(pop)的时间复杂度为 (O(1)),如果删除的是最后一个元素。如果是删除中间元素,则时间复杂度为 (O(n)),因为需要移动后续元素。

优缺点

  • 优点
    • 支持随机访问,时间复杂度为 (O(1))。
    • 动态调整大小,使用方便。
  • 缺点
    • 由于需要预留额外空间,可能会浪费一些内存。
    • 在需要频繁扩展容量时,会有一定的性能开销。

其他特性

  • 异质性:列表可以存储不同类型的对象。
  • 嵌套:列表可以包含其他列表(嵌套列表)。
  • 切片:支持切片操作,可以方便地访问部分列表。

实现细节

在 CPython 实现中,列表的底层结构如下所示:

typedef struct {PyObject_VAR_HEADPyObject **ob_item;Py_ssize_t allocated;
} PyListObject;
  • ob_item 是一个指向元素数组的指针。
  • allocated 表示已分配的数组容量。

总结起来,Python 列表的底层实现基于动态数组,结合了高效的随机访问和动态扩展的优点,但也带来了内存管理和扩展时的性能开销。了解这些细节可以帮助我们在使用列表时做出更优化的选择。

数据结构时间复杂度是什么

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/14654.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IT廉连看——UniApp——事件绑定

IT廉连看——UniApp——事件绑定 这是我们上节课最终的样式; 一、现在我有这样一个需求,当我点击“生在国旗下,长在春风里”它的颜色由红色变为蓝色,该怎么操作? 这时候我们需要一个事件的绑定,绑定一个单…

使用 Docker 部署 Jenkins 并设置初始管理员密码

使用 Docker 部署 Jenkins 并设置初始管理员密码 每一次开始,我都特别的认真与胆怯,是因为我期待结局,也能够不会那么粗糙,不会让我失望,所以,就多了些思考,多了些拘束,所以&#xf…

【HCIP学习】STP协议

一、STP协议出现背景(Spanning Tree Protocol,生成树协议) 二层环路带来的问题:广播风暴; MAC地址表的震荡; 二、STP定义 stp是二层网络中用于消除环路的协议,通过阻断冗余链路来消除&#xff…

Flutter 中的 Hero 小部件:全面指南

Flutter 中的 Hero 小部件:全面指南 在 Flutter 中,Hero 动画是一种流行的动画效果,用于在不同路由(页面)之间传递小部件,从而创建平滑的共享元素过渡效果。这种动画可以增强用户的视觉体验,使…

加速度传感器的冲击振动的原始特征与解算(部分)

这里是工作中测得的一组数据,设备有多个加速度传感器通道,我们可以看到冲击振动发生前后,各个振动传感器的的反馈以及其他的细化特征: 1.随机振动(加速度传感器视角) 2.冲击振动(加速度&#x…

Android Settings系统属性读写

Settings系统属性存储均为xml,分三种: 1.global:所有的偏好设置对系统的所有用户公开,第三方APP有读没有写的权限; 源码地址:frameworks/base/core/java/android/provider/Settings.java 对应xml路径&…

C++ 网络编程

一、Reactor 网络编程模型 reactor 是一个事件处理模型。网络处理:因为用户层并不知道 IO 什么时候就绪,所以将对 IO 的处理转化为对事件的处理。网络模型构成: 非阻塞 IO:操作 IO,如果 IO 未就绪,IO 函数会立刻返回。IO 多路复用:检测多路 IO 是否就绪。工作流程: 注册…

【从零开始实现stm32无刷电机FOC】【理论】【1/6 电机旋转本质】

目录 电机旋转需要什么样的力?怎么产生力矢量?怎么产生任意的线圈磁矢量? 电机旋转需要什么样的力? 电机切向存在受力,电机就会旋转。 进一步查看电机结构,分为转子和定子,大部分情况下&#…

Spark的概述、核心、组成、运行模式

一、Spark概述 Apache Spark 是一个快速的, 多用途的集群计算系统, 相对于 Hadoop MapReduce 将中间结果保存在磁盘中, Spark 使用了内存保存中间结果, 能在数据尚未写入硬盘时在内存中进行运算。Spark 是一个计算框架,可以用来代替Hadoop中的MapReduce计算框架。 二…

FIFO-Diffusion,一个无需额外训练即可生成长视频的框架。通过确保每个帧引用足够多的先前帧来生成高质量、一致的长视频。

简单来讲,FIFO-Diffusion先通过一些模型如VideoCraft2、zeroscope、Opem-Sora Plan等与FIFO-Diffusion的组合生成短视频,然后取结尾的帧(也可以取多帧),再用这一帧的图片生成另一段短视频,然后拼接起来。FI…

【MySQL精通之路】存储引擎-MySQL8.0中的差异

存储引擎是MySQL组件,用于处理不同表类型的SQL操作。 InnoDB是默认的、最通用的存储引擎,Oracle默认使用其创建表。(MySQL 8.0中的CREATE TABLE语句默认创建InnoDB表。) MySQL Server使用可插拔存储引擎体系结构,使存储…

linux命令日常使用思考

linux命令日常使用思考 复制的相关问题scp和cp的区别root192.168.5.229-r的理解 更新版本的相关问题svn info 根目录和家目录的区别根目录家目录 复制的相关问题 scp和cp的区别 安全性:SCP 是基于 SSH 的加密传输协议,可以保证数据在传输过程中的安全性…

vue期末复习选择题1

1. 下面哪一项描述是错误的?(B) A.$("ul li:gt(5):not(:last)")选取ul标记里面索引值大于5且不是最后一个的li元素B.$("div").find("span")选取div元素的子元素spanC.$("div.showmore > a")选取…

Axure RP 9 for Mac/win:重新定义交互原型设计的未来

在当今数字化时代,交互原型设计已成为产品开发中不可或缺的一环。Axure RP 9作为一款功能强大的交互原型设计软件,凭借其出色的性能和用户友好的界面,赢得了广大设计师的青睐。 Axure RP 9不仅支持Mac和Windows两大主流操作系统,…

Excel实现将A列和B列的内容组合到一个新的列(例如C列)中,其中A列的每个值都与B列的所有值组合。

利用Excel中vba代码宏实现 原始数据: 自动生成后数据: vba实现代码: Sub CombineColumns()Dim ws As WorksheetDim lastRowA As Long, lastRowB As Long, i As Long, j As LongDim MyIndex As IntegerDim strCombine As String, strColA As…

主流容器工具对比以及重点推荐学习的企业级工具

常见的主流容器工具包括但不限于以下几种: 1. Docker: Docker 是最流行的容器平台之一,它允许开发者将应用及其依赖打包到一个轻量级、可移植的容器中,然后可以在任何支持Docker的系统上运行。 2. Kubernetes:Kubern…

【Python】 去除字符串中的所有空白字符

基本原理 在Python中,字符串(String)是不可变的数据类型,这意味着一旦创建了一个字符串,就不能修改它的内容。然而,我们可以创建一个新的字符串,它包含原始字符串中的字符,但不包含…

局域网传文件怎么操作?轻松实现文件共享!

在现代的办公和生活中,局域网传文件已经成为一种非常常见和方便的方式,可以快速、安全地在局域网内进行文件传输。无需依赖互联网,局域网传文件可以帮助团队成员之间共享文件、备份数据、进行协作等。本文将介绍三种常见的方法,帮…

MySQL——存储过程,触发器

BaiduComate: # 问题1: # 问题1: 帮我创建两个表student与score表,要求student表有id,createDate,userName,phone,age,sex,introduce, 要求score表有id&…

Vue3实战Easy云盘(四):使用空间+文件预览+文件分享+文件下载

一、空间使用 Framework.vue中 (1)引入接口 const api {getUseSpace: "/getUseSpace",logout: "/logout", }; (2)回调 // 使用空间 const useSpaceInfo ref({ useSpace: 0, totalSpace: 1 }); const g…