快捷搜索:

.NET基础 - 简单几句说说GC(垃圾回收器)

.NET的Framework包孕两大年夜部分,其一为BCL(根基类库),其二为CLR(公共说话运行库),这里要说的恰是CLR中的GC(Garbage Collector),俗称垃圾收受接收器。

我们不如先用正规的措施描述一下垃圾收受接收中的几个要点:

(1)CLR创建工具时,发明CLR所节制的堆中的内存不够以创建该工具,触发GC进行垃圾网络。

(2)等待当前所有.NET利用法度榜样处于挂起状态下,才真正开始网络动作,并非顿时履行,也没有法子急速履行!

(3)为共享堆中所有被引用的工具建立“白名单”,同时将所有带有析构标志位的工具统一放置到FReachable的 “红名单”中(先要熬煎一下再开释)。

(4)开始开释,详细的形式呢便是把“白名单”中的工具统一移动到堆的底部,其他没有点到名的,就会被开释掉落啦,同时将堆指针更新到可用工具最高的那个位置。

(5)现在来处置惩罚红名单中的哥几个,GC先履行这些工具中的析构函数,同时重置析构标志为“已处置惩罚”,然后等待他们的便是下一次的清理,在那之前这些哥们还都在堆里。

下面再对上面的几个步骤做一下阐明:

(1)为工具创建析构函数的目的是为了开释掉落非托管资本(即GC管不到的CLR外的,可以理解为OS资本),当然,我们也可以经由过程编写Dispose()措施来手动开释非托管资本,但不会开释掉落堆中的资本。

(2)不像C++中对析构函数的应用,.NET中应只管即便少地应用析构函数,由于假如析构函数过多,我们必须至少调用两次GC收受接收,才能真正开释出资本。

(3)我们可以经由过程编码为GC添加或削减内存压力,目的只有一个,便是借此来节制网络的机会。

(4)充分斟酌到GC网络的范围限定,在编写必要调用非托管资本的利用时,建议供给Dispose()措施和析构函数两个手段,当然,我们可以经由过程应用公共代码的要领,来包管两者的事情不会呈现冲突。这样我们将得到机动的处置惩罚能力。

(5)同时,我们可以设定有关GC的一些操作特点,包括是否关闭多线程调用及是否对2代进行资本网络等等。

(6)堆分为三代:0,1,2,其容量徐徐递增,但其生动程度逐层递减,每次网络后,“白名单”中的哥们都邑自动进级,很显着,级数越高,证实应用的光阴越长,越可能是全局的一些内容。

您可能还会对下面的文章感兴趣: