JVM
- 线程隔离区:虚拟机栈(生命周期和线程相同),本地方法栈(执行native方法),程序计数器(当前线程所执行的字节码的行号指示器,执行native方法时为空)
- 共享区:栈(存放对象实例和数组),方法区(加载的类信息,静态变量,常量,即时编译后的代码)
垃圾收集算法:
- 标记清除:空间碎片过多,效率不高(G1,CMS)
- 复制算法:可用内存缩小,对象存活率高时效率低(Serial,ParNew,Parallel Scavenge)
- 标记整理:老年代算法
- 分代收集
GC Roots:全局性的引用(常量,类静态变量),执行上下文
- 虚拟机栈中引用的对象
- 方法区中的类静态属性引用的对象
- 方法区中常量引用的对象
- 本地方法栈中JNI引用的对象
新生代和老年代的默认比例是1:2
新生代(Eden区(Java对象),ServivorFrom,ServivorTo)(8:1:1)
引用计数法,root搜索算法
长期存活的对象会进入老年区,默认为15
垃圾收集器:
- 新生代:Serial ,ParNew,Parallel Scavenge
- 老年代:CMS,Serial Old MSC,Parallel Old
- Serial:新生代采用复制算法,暂停所有用户线程,(Client模式下新生代的默认收集器)
- ParNew收集器:Serial多线程版本,采用复制算法(多线程)(Server模式下新生代收集器)
- Parallel Scavenge:复制算法,并行多线程,达到可控制的吞吐量(CPU用于运行用户代码的时间与消耗的总时间的比值)
- Serial Old:单线程,标记整理算法(Client模式下虚拟机使用,与Parallel Scavenge搭配使用)
- Parallel Old:老年代收集器,多线程,标记整理算法
- CMS(Concurrent Mark Sweep):最短停顿时间,老年代,标记清除算法,(初始标记stop the world,并发标记,重新标记stop the world,并发清除),对CPU资源敏感,无法处理浮动垃圾(并发清理阶段用户线程依然在运行),会产生大量碎片触发Full GC
- G1收集器:并发与并行,分代收集,空间整合(整体上采用标记整理,局部采用复制算法),可预测的停顿(有计划的避免在整个Java堆中进行全区域的垃圾收集,通过维护优先列表,每次根据允许时间,回收价值最大的Region)(初始标记,并发标记,最终回收,筛选回收)
网友评论