文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python语言开发垃圾回收机制原理的示例分析

2023-06-25 12:36

关注

这篇文章主要介绍python语言开发垃圾回收机制原理的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

一.什么是垃圾回收机制

垃圾回收机制(简称GC), 解释器自带的一种机制

它是一种动态存储管理技术,自动释放不再被程序引用的对象所占用的内存空间

二.为什么要有垃圾回收机制

程序的运行过程中会申请大量的内存空间

对于一些无用的空间如果不及时清理的话会导致内存溢出(不够用),程序就会崩溃

管理内存是非常复杂的事情,垃圾回收机制就把程序员从复杂的内存管理中解放出啦

三.垃圾回收机制的原理

1.引用计数

引用计数就是变量名与变量值的关联次数, 以此来跟踪和回收垃圾

直接引用

通过变量名直接引用

x = 18  #18被引用了一次,计数为1y = x   #18被引用加1次,计数为2z = y   #18被引用加1次,计数为3print(id(x))  #140725488808736print(id(y))  #140725488808736print(id(z))  #140725488808736
间接引用

容器对其的引用都是间接

x = 18                 #18被引用一次,计数为1li = [1,2,x]           #通过列表引用,计数加1,为2dic = {'age': x}       #通过字典引用, 计数加1,为3print(id(x))           #140725486514976print(id(li[2]))       #140725486514976 列表引用,计数4print(id(dic['age']))  #140725486514976 字典引用,计数5

2.栈区 / 堆区

栈区 : 存放的是变量名与变量值的内存地址映射关系

堆区 : 存放的是值真正的位置

python语言开发垃圾回收机制原理的示例分析

3.总结

直接引用指的是从栈区出发直接引用到的内存地址

间接引用指的是从栈区出发引用到堆区后,再通过进一步引用才能到达的内存地址

四.标记清除

1.循环引用问题(也叫交叉引用)

#我们先定义列表l1=[0]  # 列表1被引用一次,列表1的引用计数变为1   l2=[1]  # 列表2被引用一次,列表2的引用计数变为1   #将列表加入另一个列表l1.append(l2)  # 把列表2追加到l1中作为第二个元素,列表2的引用计数变为2l2.append(l1)  # 把列表1追加到l2中作为第二个元素,列表1的引用计数变为2#解除比变量名"l1"和"l2"与值的对应关系del l1del l2

2.循环引用导致的结果

值不再被任何名字关联,但是值的引用计数并不会为0

应该被回收但又不能被回收

3.解决方法 : 清除-标记

容器对象的的引用都有可能产生循环引用, 而清除-标记就是为解决这个问题的

当应用程序可用空间被耗尽时, 清除-标记会停止整个程序, 然后先标记, 再清除

五.分代回收

1.效率问题

基于引用计数的回收机制,每次回收内存,都需要把所有对象的引用计数都遍历一遍

这是非常消耗时间的,于是引入了分代回收来提高回收效率

分代回收采用的是用**“空间换时间”**的策略。

2.解决方法 : 分代回收

分代

分代指的是根据变量的存活时间来划分他们的等级
一个变量经常被引用,等级(权重)就会提高,权重达到设定值就会进入下一个等级
当经过多次扫描都没有被回收,"GC机制"就会认为该变量是常量
于是对其的扫描频率会降低

python语言开发垃圾回收机制原理的示例分析

回收

当计数降低,就容易被回收
分代回收可以起到提升效率的效果,但也存在一定的缺点:
       比如一个变量刚从低等级转入高等级,它就被解除了绑定关系
       它应该被回收,但高等级扫描频率低于低等级
       那么这个已被解除绑定关系的变量无法及时得到清理

以上是“python语言开发垃圾回收机制原理的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯