Java的堆空间存储满了,程序就会崩溃,如何科学的进行垃圾回收呢?那么我们就得用到GC了。
GC回收判断的标准: GC Root,被栈,本地方法栈,方法区的静态常量或者变量直接或者引用的对象时不能被删除的。
回收的不同方式
- 标记清理
将需要回收的对象进行标记,将需要标记的对象标记完后,在回收的时候就将标记的对象给删除就行。
缺点: 产生内存碎片,清理后的空间分散内存不能统一使用。 - 标记整理
对需要回收哦的对象进行标记,在回收的时候删除掉标记的对象,并将没有删除的对象都往前挪动,腾出空闲的全部空间供其他对象使用。
缺点: 代价大,每删除一个对象都要挪动一遍 - 复制算法
将内存分区,需要保存的复制到另一个区域,不需要的不进行复制,然后将原区域删除。
缺点: 需要两倍的内存
实际的GC![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/cc7cf7197c7c37dcab037ff04cf81b5a.png)
将堆区进行划分,分为年轻代,老年代,年轻代又分为eden,s1,s2区,比例是8:1:1。产生对象一般都是在eden区,在年轻代使用的时yang GC ,采用的是复制算法,内存要满的时候将需要删除的打上标记,不需要删除的就复制在s1区或者s2区,一般都是s1或者s2中的一个配合E区进行打标复制删除,两个s区交替复制删除。每一次yangGC进行删除的时候,幸存下来的对像都会标记+1,当标记达到15次的时候,就会将对象存放到old区,或者是大对象。old的内存要满了的时候,也会GC,同时也会伴着yang GC,所以也叫做full GC,full GC会引发start the world,java进程将会停止,全力清除内存,满足需要。
标记清理主要用于full GC,复制主要用于yang区的GC.
不同的垃圾回收器
yang区的垃圾回收器: ParNew ,复制算法
old区垃圾回收器:CMS,标记清理算法
最新版的垃圾回收器:不建议使用ParNew和CMS,而是用全新的 G1