python语言开发垃圾回收机制原理教程

 更新时间:2021年11月01日 14:27:20   作者:FikL-09-19  
这篇文章主要为大家介绍了python语言开发垃圾回收机制原理的教程有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步

一.什么是垃圾回收机制

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

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

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

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

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

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

三.垃圾回收机制的原理

1.引用计数

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

直接引用

通过变量名直接引用

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

间接引用

容器对其的引用都是间接

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

2.栈区 / 堆区

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

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

在这里插入图片描述

3.总结

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

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

四.标记清除

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

#我们先定义列表
l1=[0]  # 列表1被引用一次,列表1的引用计数变为1   
l2=[1]  # 列表2被引用一次,列表2的引用计数变为1   

#将列表加入另一个列表
l1.append(l2)  # 把列表2追加到l1中作为第二个元素,列表2的引用计数变为2
l2.append(l1)  # 把列表1追加到l2中作为第二个元素,列表1的引用计数变为2

#解除比变量名"l1"和"l2"与值的对应关系
del l1
del l2

2.循环引用导致的结果

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

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

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

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

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

  • 标记
    但凡是可以从栈区出发,找到对应堆区内容的(直接或间接引用)就标记存活,非存活则清除
    具体点:标记的过程其实就是,遍历所有的"GC Roots"对象(栈区中的所有内容或者线程都可以作为"GC Roots"对象)
    然后将所有"GC Roots"的对象可以直接或间接访问到的对象标记为存活的对象,其余的均为非存活对象,应该被清除
  • 清除
    遍历堆中的对象,将没有标记存活的对象都清理掉

五.分代回收

1.效率问题

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

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

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

2.解决方法 : 分代回收

分代

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

在这里插入图片描述

回收

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

总结

垃圾回收机制是在清理垃圾和释放内存的前提下
允许一些垃圾不被释放为代价(就是等级权重高点的垃圾不会及时被清理)
以此换取引用计数扫描频率的降低,从而提升其性能
这是一种以空间换时间的解决方案

以上就是python语言开发垃圾回收机制原理教程的详细内容,更多关于python语垃圾回收机制原理的资料请关注脚本之家其它相关文章!

相关文章

  • 9行Python3代码实现批量提取PDF文件的指定内容

    9行Python3代码实现批量提取PDF文件的指定内容

    这篇文章主要为大家详细介绍了如何通过9行Python3代码实现批量提取PDF文件的指定内容,文中的示例代码讲解详细,感兴趣的小伙伴可以尝试一下
    2022-12-12
  • Python使用pdfminer库玩转PDF文本提取

    Python使用pdfminer库玩转PDF文本提取

    pdfminer是一个开源的Python第三方库,专门用于解析PDF文件,本文主要为大家详细介绍了如何使用pdfminer实现PDF文本提取,有需要的小伙伴可以了解下
    2025-02-02
  • 基于Python实现计算纳什均衡的示例详解

    基于Python实现计算纳什均衡的示例详解

    纳什均衡是一种博弈论中的概念,它描述了一种平衡状态,其中每个参与者都不能通过独立改变其决策来提高自己的利益。本文就来用Python中的Nashpy和PuLP实现计算纳什均衡,感兴趣的可以了解一下
    2023-02-02
  • PyCharm安装库numpy失败问题的详细解决方法

    PyCharm安装库numpy失败问题的详细解决方法

    今天使用pycharm编译python程序时,由于要调用numpy包,但又未曾安装numpy,于是就根据pycharm的提示进行安装,最后竟然提示出错,下面这篇文章主要给大家介绍了关于PyCharm安装库numpy失败问题的详细解决方法,需要的朋友可以参考下
    2022-06-06
  • python多线程编程中的join函数使用心得

    python多线程编程中的join函数使用心得

    这篇文章主要介绍了python多线程编程中的join函数使用心得,本文先是给出了join函数使用例子,并对join函数的使用作了总结,需要的朋友可以参考下
    2014-09-09
  • Anaconda中利用conda创建、激活、删除、添加新环境

    Anaconda中利用conda创建、激活、删除、添加新环境

    在使用Python开发项目或者编写脚本的时候通常需要建立不同版本的Python的虚拟环境,本文主要介绍了Anaconda中利用conda创建、激活、删除、添加新环境,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04
  • django中SMTP发送邮件配置详解

    django中SMTP发送邮件配置详解

    这篇文章主要介绍了django中SMTP发送邮件配置,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • python之Character string(实例讲解)

    python之Character string(实例讲解)

    下面小编就为大家带来一篇python之Character string(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • 深入理解numpy广播机制

    深入理解numpy广播机制

    广播(Broadcast)是 numpy 对不同形状(shape)的数组进行数值计算的方式,本文深入理解numpy广播机制,具有一定的参考价值,感兴趣的可以了解一下
    2023-09-09
  • Python 实现判断图片格式并转换,将转换的图像存到生成的文件夹中

    Python 实现判断图片格式并转换,将转换的图像存到生成的文件夹中

    今天小编就为大家分享一篇Python判断图片格式并转换,将转换的图像存到生成的文件夹中,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-01-01

最新评论