news 2026/6/10 15:36:10

离高薪测试你可能只差这个理解:python 内存管理机制

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
离高薪测试你可能只差这个理解:python 内存管理机制

期有小伙伴跟我反馈 ,面试有遇到面试官问 python 内存管理机制相关的问题,因为之前没有特地的去了解过,所以不知道怎么回答。

所以今天就专门写了这篇 python 内存管理机制的文章,来给大家系统的梳理一下内存管理机制的知识点,以及面试中容易被问到的问题。

通过这篇文章帮你们轻松通关面试中 python 内存管理机制相关的问题。

01.引用计数机制

引用计算机制是咱们 python 中垃圾回收的主要机制,python 解释器会根据对象的引用计数是否为零,来对进行垃圾回收,释放内存。接下来我们先来看看什么是引用计数。

我们先来看一个最简单的 python 赋值语句

>>> a = 10

这边给变量 a 赋值了一个数值类型的对象 10, 那么在内存中存储的时候,a 这个变量指向的是 10 这个对象,此时 10 这个对象的引用计算会加 1。

>>> b=a

当我们再把 a 赋值给变量 b 时,b 引用的也是 a 这个变量引用的值 10,那么这个时候 10 这个对象的引用计数又会加 1。

_

引用计数增加:

● 对象被创建

● 对象被别的变量引用(赋值给一个变量)

● 对象被作为元素,放在容器中(比如被当作元素放在列表中)

_

引用计数减少:

● 对象的别名被显式的销毁

● 对象的一个别名被赋值给其他对象 (例:比如原来的 a=10,被改成 a=100,那么此时 10 的引用计数就减少了)

● 对象从容器中被移除,或者容器被销毁(例:对象从列表中被移除,或者列表被销毁)

● 一个引用离开了它的作用域(调用函数的时候传进去的参数,在函数运行结束后,该参数的引用即被销毁)

_

引用计数查看

咱们如果要查看对象的引用计数,可以通过内置模块 sys 提供的 getrefcount 方法去查看。

  1. import sys

  2. obj =[11,22,33]

  3. print(sys.getrefcount(obj))

AI写代码

注意点:当使用某个引用作为参数,传递给 getrefcount()时,参数实际上创建了一个临时的引用。因此,getrefcount()所得到的结果,会比期望的多 1 ;对应一些常用的基本数据看到的引用计数值会比较大(因为 python 内部引用)

02.数据池和缓存

1

小整数池

  1. a=1000

  2. a1=1000

  3. b = 10

  4. b1 = 10

  5. # a和a1是否为同一个对象?,b和b1是否为同一个对象?

AI写代码

问题:a 和 a1 是否为同一个对象?,b 和 b1 是否为同一个对象?

答案:b 和 b1 是同一个对象,a 和 a1 不是

为什么会出现上述情况呢?

当运行 python 程序时,Python 自动将-5~256 的整数进行了缓存,放在一个‘池’(小整数池)中,无论程序中那些变量指向这些范围内的整数或者字符串当你将这些整数赋值给变量时,并不会重新创建对象,而是使用已经创建好的缓存对象。

优点:对于一些常用的整数,直接从‘池’里拿来用,避免频繁的创建和销毁,提升效率,节约内存

2

intern 机制

intern 机制,也称为字符串驻留池,是针对于字符串内存管理的一种优化处理的机制。​​​​​​​

  1. In [4]: s1='abc'

  2. In [5]: s2 ='abc'

  3. In [6]: s2 is s2

  4. Out[6]: True

  5. In [7]: s3='abc?'

  6. In [8]: s4 = 'abc?'

  7. In [9]: s3 is s4

  8. Out[9]: False

  9. #为什么会出现这种情况,同样是字符串为什么上面两次赋值,是同一个对象,下面不是。

intern 机制的优点是,在创建新的字符串对象时(如果字符串只包含数字、字母、下划线),会先在字符串驻留池里面找是否有已经存在的值相同的对象,如果有,则直接拿过来用(引用),避免频繁的创建和销毁内存,提升效率。

3

缓存机制

● float、int 、list 等一些内置的数据类型,会缓存 80 个对象

● 元组 会根据元组数据的长度,分别缓存元组长度为 0-20 的对象。

● 其他的自定义类型一般都是缓存 2 个对象

03.垃圾回收机制

● python 的垃圾回收机制用一句话来形容就是:引用计数机制为主,标记-清除和分代收集两种机制为辅的策略

1

引用计数

● 引用计数:在之前讲对象的引用我们讲到了,每个对象创建之后都有一个引用计数,当引用计数为 0 的时候,那么此时的的垃圾回收机制会自动把它销毁,回收内存空间。

● 引用计数存在一个缺点那就是当两个对象出现循环引用的时候,那么这个两个变量始终不会被销毁,这样就会导致内存泄漏。

2

标记清除:

首先标记对象(垃圾检测),然后清除垃圾(垃圾回收),首先初始所有对象标记为白色,并确定根节点对象(这些对象是不会被删除),标记它们为黑色(表示对象有效),将有效对象引用的对象标记为灰色(表示对象可达,但它们所引用的对象还没检查),检查完灰色对象引用的对象后,将灰色标记为黑色。重复直到不存在灰色节点为止。最后白色结点都是需要清除的对象。

3

分代回收

分代回收是一种以空间换时间的操作方式,Python 将内存根据对象的存活时间划分为不同的集合,每个集合称为一个代,Python 将内存分为了 3“代”,分别为年轻代(第 0 代)、中年代(第 1 代)、老年代(第 2 代),他们对应的是 3 个链表,它们的垃圾收集频率随着对象存活时间的增大而减小。

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:35:38

别再死磕降重技巧!8款AI论文神器一键替换高级表达更高效

别再傻傻地当“学术裁缝”了!你是不是还在为论文查重率抓狂,熬夜对着标红的段落,绞尽脑汁地“同义词替换”、“调换语序”?这种低效、痛苦且风险极高的做法,正在浪费你宝贵的研究时间,甚至可能让你的论文在…

作者头像 李华
网站建设 2026/6/6 13:57:18

【智谱Open-AutoGLM手机部署全攻略】:手把手教你本地运行AI大模型

第一章:智谱Open-AutoGLM手机部署概述智谱AI推出的Open-AutoGLM是一款面向移动端优化的轻量化大语言模型,专为在资源受限设备上实现高效推理而设计。该模型通过结构压缩、量化加速与硬件适配等技术,在保持较强语义理解能力的同时,…

作者头像 李华
网站建设 2026/6/10 14:56:50

Open-AutoGLM + Windows 环境搭建全记录(仅限内部分享的技术细节)

第一章:Open-AutoGLM Windows 环境搭建全记录(仅限内部分享的技术细节)环境准备与依赖安装 在开始部署 Open-AutoGLM 之前,确保系统已安装 Python 3.9 或更高版本。推荐使用 Conda 管理虚拟环境,以避免依赖冲突。下载…

作者头像 李华
网站建设 2026/6/10 14:56:31

TensorFlow在音乐作曲辅助中的创造性应用

TensorFlow在音乐作曲辅助中的创造性应用 在数字创作的浪潮中,人工智能正悄然重塑艺术表达的边界。曾经被认为完全依赖人类灵感与情感的音乐作曲,如今也迎来了算法的参与。尤其是在短视频、游戏配乐、广告背景音等对内容生产效率要求极高的场景下&#…

作者头像 李华
网站建设 2026/6/10 14:36:56

【专家亲授】Open-AutoGLM在Linux中的三大坑及避坑方案

第一章:Open-AutoGLM简介与部署准备Open-AutoGLM 是一个开源的自动化通用语言模型框架,专注于提升大语言模型在复杂任务中的自主推理与执行能力。该框架融合了思维链(Chain-of-Thought)、工具调用(Tool Calling&#x…

作者头像 李华