基本概念:GC(Garbage Collection)是java虚拟机的精华所在,GC完成的任务是对内存的管理,不需要java程序员管理内存。
GC管理的内存:java堆(存放java实例)和方法区;java虚拟机栈、程序计数器和本地方法栈(线程私有,随着线程消失释放)。
GC回收时机:
java堆:实例对象不可达(没有指向该对象的引用)
方法区:无用类与废弃类;判断废弃类,当且仅当满足下面三个条件(1.所有类实例被回收;2.加载该类的ClassLoader被回收;3.该类对应的java.lang.Class对象没有地方被引用,无法在任何地方通过反射访问到该类)
GC如何回收:
GC回收算法:
- 标记-清除算法(需要两步)
标记:标记需要清除的对象
清除:释放当前内存
优点:简单易于实现
缺点:产生大量的内存碎片
- 复制算法(把当前内存分为两块)
第一块用于当前内存申请;第二块在第一块用完的时候,把第一块中的对象复制到第二块,然后清除第一块,如此循环往复。
优点:不用考虑内存碎片;顺序分配内存;
缺点:可用内存是原来内存的一半,代价高;
- 标记-整理算法
标记:标记出没有引用的对象
整理:所有存活的对象移到内存一端,清理掉除边界以外的内存;
优点:内存代价小;不易产生内存碎片
缺点:算法复杂
- 分代收集算法
根据对象存活的周期不同,分为几代,然后组合使用前面三种算法。