JAVA JVM 垃圾收集器

垃圾收集算法

  1. 标记清除法
  2. 复制法
  3. 标记整理法
  4. 分代收集法

缺点

  1. 标记清除法:
    原理: 从根开始扫描,标记所有的存活对象(可达对象),然后对所有未标记的对象进行清除操作。
    缺点: 清除后会产生不连续内存,内存碎片,导致资源浪费。
  2. 复制法:
    原理: 把一块区域切分成2份,从s1把所有存活对象进行复制到s2区域,然后把s1的清除。
    缺点: 资源分为2块,运行时只使用一份区域,另一个区域空闲,导致资源浪费。
  3. 标记整理法:
    原理: 扫描标记与标记清除法一样,但是他在清除前还有一步,整理步骤。首先对存活对象进行标记,然后对标记对像向一端进行移动整理,然后清除另一端。
    缺点: 步骤添加,所以性能消耗会大

分代收集法

分为年轻代,老年代。
年轻代:垃圾回收时都会对很大一部分对象进行回收,所以内存占用比较小,而且gc频率会略高。一般会使用复制法。
老年代:垃圾回收时,一般都是较小的进行回收,因为到老年代的对象,一般都是默认经过15次回收才到老年代,所以大部分都是使用中。一般会使用标记清除或标记整理法。

垃圾回收器产品

  1. serial 使用在年轻代,串行gc
  2. ParNew 使用在年轻代,并行gc
  3. Parallel Scavenge 使用在年轻代,并行gc
  4. serial old 使用在老年代,串行gc
  5. parallel old 使用在老年代,并行gc
  6. cms 使用在老年代,并发gc(据说能做还可以设置还精准stw的时间)

serial会与serial old或cms搭配使用
parnew会与serial old 或cms搭配使用
parallel scavenge会与parallel old搭配使用

你可能感兴趣的:(java)