设为首页 收藏本站
查看: 689|回复: 0

[经验分享] Python的垃圾回收机制

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-9-1 10:35:09 | 显示全部楼层 |阅读模式
                      垃圾回收机制:
引用计数(缺陷是1,维护引用计数消耗资源,2,循环引用)为主,标记--清除和分代收集为辅
如果一个对象的引用为0,系统就会回收这个对象的内存

1,引用计数+1的情况:
1,对象被创建,a=23
2,对象被引用,b=a
3,对象被作为参数,传入到一个函数中,fun(a)
4,对象被作为一个元素,存储到容器中,list=[a,a]
2,引用计数-1的情况:
1,对象的别名被显示销毁,del a
2,对象的别名被赋予新的对象,a=24
3,一个对象离开它的作用于=域,fun函数执行完毕时,fun中函数局部变量(全局变量不会)
4,对象所在的容器被销毁,或从容器中销毁对象

3,查看一个对象的引用计数:
sys.getrefcount(a)可以查看a对象的引用计数,但是比正常计数大1(因为调用函数的时候传入a,这会让他的引用计数+1)

循环引用导致内存泄漏:
def f2():
while True:
c1=ClassA()
c2=ClassA()
c1.t=c2
c2.t=c1
del c1
del c2
c1,c2的引用都不是0,这两个对象都是可以被销毁的(del),但是由于循环引用,导致垃圾回收机制不会回收他们,所以就会导致内存泄漏。


标记-清除机制:
首先标记对象(垃圾检测),然后清除垃圾(垃圾回收)

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

回收对象的组织:

链表:通过指针将每个回收对象连接起来,形成了一个链表

一个完整的收集过程:链表建立,确定根节点,垃圾标记,垃圾回收



垃圾回收:
垃圾回收后的对象会放在gc.garbage()列表里面
gc.collect()会返回不可达的对象数目
有三种情况会触发垃圾回收:
1,调用gc.collect()
2,当gc模块的计数器达到阀值的时候
3,程序退出的时候

gc模块:
Garbage Collector interface
gc模块提供一个接口给开发者设置垃圾回收的选项。上面说到,采用引用计数的方法管理内存的一个缺陷是循环引用,而gc模块的一个主要功能就是解决循环引用的问题

分代技术:

分代技术是一种典型的以空间换时间的技术,对象存在时间越长,越可能不是垃圾,应该越少去收集。

这样的思想,可以减少标记-清除机制所带来的额外操作。分代就是将回收对象分成数个代,每个代就是一个链表(集合),代进行标记-清除的时间与代内对象存活时间成正比例关系。

python里一共有三代,每个代的阀值表示该代最多容纳对象的个数。默认情况下,当0代超过700,或1,2代超过10,垃圾回收机制将触发。

0代触发将清理所有三代,1代触发会清理1,2代,2代触发后只会清理自己。


                  


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-403726-1-1.html 上篇帖子: python的httplib、urllib和urllib2的区别及应用 下篇帖子: python自动化运维之多线程
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表