• GC原理知多少


    GC (Garbage Collector) 垃圾回收器

             GC是对内存的管理,计算机的内存是有限的,早期的C/C++是没有GC的,需要编程者手动回收内存,主要是那时候内存小,程序员重视对内存的管理,但是也存在内存回收时机和忘记回收的问题,会造成内存泄露的灾难。

             随着Java的JVM对内存的管理的发展,以及随之而来的CLR对内存的管理,在内存管理上,逐步解放程序员的对内存的管理,使程序员可以将精力集中在功能实现等方面,但是GC存在两个问题:

      1 GC不能回收非托管代码(stream文件流、数据库连接和COM组件)

      2 GC回收内存的时机是不确定的,即失去了对内存的管理

      .Net的内存分为堆和栈,栈用来存放值类型,堆用来存放引用类型,而GC回收机制针对引用类型,对于垃圾的简单判断是该对象及其子对象都没有被引用。由于回收机制的优缺点和适应语言的发展,衍生出各种回收方法。

    GC垃圾回收方法:

      Mark-sweep 主要包括标记阶段和清除阶段

        标记阶段:遍历内存中的对象,将活动对象进行标记

        清除阶段:遍历内存中的对象,将未标记的对象进行清除,并在此时进行内存合并

      引用计数法:给对象添加引用计数器,新建对象的计数为1,当对象被引用时计数加一,当对象引用失效时计数减一,当计数为零时对象被回收。

      GC复制法:将堆区分为From和To,大小1:1,新的对象存放在From区,当From区满的时候,将非垃圾对象搬移到To区,清除From区并互换From和To分区的名字,继续分配From区的空间。

      分代回收法:.Net是将内存分为Generation-0/1/2三代,初始化时三代划分一定的空间,新创建的对象存放在0区,新对象存活时间短,旧对象存活时间长,0区GC一次存活对象搬移到1区,1                          区GC一次存活对象搬移到2区,每个区会根据对象的多少自动增加或减少空间。Java是将内存分为新生代、老年代和永久代。

    .Net对于非托管代码的内存管理

      1 继承 IDispose接口,实现Dispose方法,对内存进行释放

      2 Finalize,析构函数实现内存释放

      3 GC.SuppressFinalize(this) 将方法1和2综合起来

  • 相关阅读:
    Luogu4113 采花(树状数组)题解
    Luogu P2572 [SCOI2010]序列操作(线段树)题解
    CF525D Arthur and Walls(贪心染色)题解
    CF425A Sereja and Swaps(暴力枚举+贪心)题解
    CF482A Diverse Permutation(贪心构造)题解
    CF545C Woodcutters(贪心)题解
    学习笔记---ST表
    python列表解析式,生成器,及部分内建函数使用方法
    python之set集合,字典详解
    使用css3写出来的表情包,酷酷的!!!
  • 原文地址:https://www.cnblogs.com/arvinzd/p/14137289.html
Copyright © 2020-2023  润新知