Python超详细讲解内存管理机制
作者:henry_rhy 发布时间:2022-02-21 23:11:47
什么是内存管理机制
python中创建的对象的时候,首先会去申请内存地址,然后对对象进行初始化,所有对象都会维护在一
个叫做refchain的双向循环链表中,每个数据都保存如下信息:
1. 链表中数据前后数据的指针
2. 数据的类型
3. 数据值
4. 数据的引用计数
5. 数据的长度(list,dict..)
一、引用计数机制
引用计数增加:
1.1 对象被创建
1.2 对象被别的变量引用(另外起了个名字)
1.3 对象被作为元素,放在容器中(比如被当作元素放在列表中)
1.4 对象被当成参数传递到函数中
import sys
a = [11,22] # 对象被创建
b = a # 对象被别的变量引用
c = [111,222,333,a] # 对象被作为元素,放在容器中
# 获取对象的引用计数
print(sys.getrefcount(a)) # 对象被当成参数传递到函数中
最后的执行结果是,a 这个变量被引用了4次
引用计数减少:
对象的别名被显式的销毁
对象的一个别名被赋值给其他对象 (例:比如原来的a=10,被改成a=100,此时10的引用计数就减少了)
对象从容器中被移除,或者容器被销毁(例:对象从列表中被移除,或者列表被销毁)
一个引用离开了它的作用域(调用函数的时候传进去的参数,在函数运行结束后,该参数的引用即被销毁)
import sys
del b # 对象的别名被显式的销毁
b = 999 # 对象的一个别名被赋值给其他对象
del c # 列表被销毁(容器被销毁)
c.pop() # 把列表数据最后一个删除掉(对象从容器中被移除)
二、数据池和缓存
数据池分为两种:小整数池 和 大整数池
小整数池(-5到256之间的数据)
运行机制:Python自动将 -5~256 的整数进行了缓存到一个小整数池中,当你将这些整数赋值给变量时,并不会重新
创建对象,而是使用已经创建好的缓存对象,当删除这些数据的引用时,也不会进行回收
超出-5到256的整数将不会在在缓存,会重新创建对象
例如:
对于超出-5到256的整数将不会在在缓存,Python会重新创建对象,返回id
# 场景1:数据为列表,不在-5~256 的范围
>>> a = [11]
>>> b = [11]
>>> id(a),id(b)
(1693226918600, 1693231858248) ========》 id 不一样
# 场景二: 数据为整数,在-5~256 的范围
>>> aa = 11
>>> bb = 11
>>> id(aa),id(bb)
(140720470385616, 140720470385616) id 一样
# 场景三: 数据不在-5~256的范围
>>> bb = -7
>>> aa = -7
>>> id(aa),id(bb)
(1843518717904, 1843518717776) id 不一样
# 场景四: 数据不在-5~256的范围
>>> a = 257
>>> b = 257
>>> id(a),id(b)
(2092420910928, 2092420911056) id 不一样
大整数池(字符串驻留池 / intern机制)
优点:在创建新的字符串对象时,会先在缓存池里面找是否有已经存在的值相同的对象(标识符,即只包含数字、字母、下划线的字符串),如果有,则直接拿过来用(引用),避免频繁的创建和销毁内存,提升效率
例如:
对于不在标识符内的数据将不会在在缓存,Python会重新创建对象,返回id
# 场景1:
>>> a = '123adsf_'
>>> b = '123adsf_'
>>> id(a),id(b)
(61173296, 61173296) ========》 id 一样
# 场景二:
>>> b1 = '123adsf_?'
>>> b2 = '123adsf_?'
>>> id(b1),id(b2)
(61173376, 61173416) id 不一样
缓存机制
对于python中常用内置数据类型的缓存:
float:缓存100个对象
list: 80个对象
dict: 80个对象
set: 80个对象
元组:会根据元组数据的长度,分别缓存元组长度为0-20的对象
来源:https://blog.csdn.net/qq_40236497/article/details/125425988


猜你喜欢
- python等待10秒执行下一命令的方法:首先导入时间(time)模块;然后在需要等待执行的命令前调用sleep()方法,并在方法的括号里将
- 本文实例讲述了python实现上传样本到virustotal并查询扫描信息的方法。分享给大家供大家参考。具体方法如下:import simp
- 在Jupyter Notebook上使用Python+opencv实现如下简单车牌字符切割。关于opencv库的安装可以参考:Python下
- 在Python中有两个函数分别是startswith()函数与endswith()函数,功能都十分相似,startswith()函数判断文本
- 本文介绍一种将一个大的文本文件分割成多个小文件的方法方法一:1.读取文章所有的行,并存入列表中2.定义分割成的小文本的行数3.将原文本内容按
- 本文较为详细的分析了php提示Failed to write session data错误的解决方法。分享给大家供大家参考。具体方法如下:一
- 与数据类型相关的字段CharField 作用:字符串字段
- 内容摘要: ASP具备管理不同语言脚本程序的能力,能够自动调用合适的脚本引擎以解释脚本代码和执行内置函数。ASP开发环境提供了两种
- 实训课期间忙里偷闲的学习了python的selenium包,唯一一点不好是要自己去查英文文档,明摆着欺负我这种英语不好的,想着用谷歌翻译一下
- 本文实例讲述了Python实现合并同一个文件夹下所有txt文件的方法。分享给大家供大家参考,具体如下:一、需求分析合并一个文件夹下所有txt
- 这篇文章主要介绍了mysql数据迁徙方法工具解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以
- 简介提到爬虫,大部分人都会想到使用Scrapy工具,但是仅仅停留在会使用的阶段。为了增加对爬虫机制的理解,我们可以手动实现多线程的爬虫过程,
- 现在有一个员工字典,类似这样的结构staff_dic = {"name":"灭霸", "a
- BeautifulSoup简介Beautiful Soup是python的一个库,最主要的功能是从网页抓取数据。官方解释如下:Beautif
- 一、区别1、 history和hash都是利用浏览器的两种特性实现前端路由,history是利用浏览历史记录栈的API实现,hash是监听l
- 一、简单说明80、90后的小伙伴都玩过“俄罗斯方块”,那种“叱咤风云”场景 偶尔闪现在脑海 真的是太爽了;如果没有来得及玩过的同学,这次可以
- 在一些朋友安装完SQL Server 2008之后大多会遇到连接出错的问题。特别对于我们这样的新手而言简直郁闷的要死,好不容易装玩了又出现了
- linspace生成有序列表,重点在数据范围与数据个数上linspace(0,1,11),即从0到1闭区间,划分为11个数据点>>
- 这里转载一篇前辈写的文章,在我自己的理解上修改了一下,仅作记录。 先贴一个国内某大公司的代码: <script type="
- 本文解决问题:批量删除多行txt文本中的内容。思路:1.找出需要删除行的 id(就是需要删除那些行,把这是第几行给记录下来。)2.将原文本内