Python 垃圾回收机制详细
2021-02-08 18:16
标签:原理 顺序 失效 org 目录 垃圾回收算法 它的 也有 节点 Python语言默认采用的垃圾收集机制是『引用计数法 『引用计数法』的原理是:每个对象维护一个 缺点:它的缺点是需要额外的空间维护引用计数,这个问题是其次的,不过最主要的问题是它不能解决对象的“循环引用”,因此,也有很多语言比如Java并没有采用该算法做来垃圾的收集机制。 标记清除(Mark—Sweep)』算法是一种基于追踪回收(tracing GC)技术实现的垃圾回收算法。它分为两个阶段:第一阶段是标记阶段,GC会把所有的『活动对象』打上标记,第二阶段是把那些没有标记的对象『非活动对象』进行回收。那么GC又是如何判断哪些是活动对象哪些是非活动对象的呢? 对象之间通过引用(指针)连在一起,构成一个有向图,对象构成这个有向图的节点,而引用关系构成这个有向图的边。从根对象(root object)出发,沿着有向边遍历对象,可达的(reachable)对象标记为活动对象,不可达的对象就是要被清除的非活动对象。根对象就是全局变量、调用栈、寄存器。 mark-sweepg 在上图中,我们把小黑圈视为全局变量,也就是把它作为root object,从小黑圈出发,对象1可直达,那么它将被标记,对象2、3可间接到达也会被标记,而4和5不可达,那么1、2、3就是活动对象,4和5是非活动对象会被GC回收。 标记清除算法作为 Python 的辅助垃圾收集技术主要处理的是一些容器对象,比如 list、dict、tuple,instance 等,因为对于字符串、数值对象是不可能造成循环引用问题。Python使用一个双向链表将这些容器对象组织起来。不过,这种简单粗暴的标记清除算法也有明显的缺点 Python 垃圾回收机制详细 标签:原理 顺序 失效 org 目录 垃圾回收算法 它的 也有 节点 原文地址:https://www.cnblogs.com/kai-/p/12770000.html
引用计数
Reference Counting
』,该算法最早George E. Collins在1960的时候首次提出,50年后的今天,该算法依然被很多编程语言使用。ob_ref
字段,用来记录该对象当前被引用的次数,每当新的引用指向该对象时,它的引用计数ob_ref
加1
,每当该对象的引用失效时计数ob_ref
减1
,一旦对象的引用计数为0
,该对象立即被回收,对象占用的内存空间将被释放import sys
class A():
def __init__(self):
‘‘‘初始化对象‘‘‘
print(‘object born id:%s‘ %str(hex(id(self))))
def f1():
‘‘‘循环引用‘‘‘
while True:
c1=A()
c2=A()
c1.t=c2
c2.t=c1
del c1
del c2
c1
,c2
后,这两个对象的引用计数都是1
,执行c1.t=c2
和c2.t=c1
后,引用计数变成2
.del c1
后,内存c1
的对象的引用计数变为1
,由于不是为0
,所以c1
的对象不会被销毁,同理,在del c2
后也是一样的。标记清楚
分代回收
上一篇:PTA-C语言编写数字金字塔
下一篇:Python 代码编辑器怎么选?