JVM包括三部分:
1. 类加载器系统。加载,连接(校验,准备,解释),初始化。类加载器:Bootstrap(/jre/lib) -> Extension(/jre/lib/ext) -> System (classpath)
2. 存储区域。五部分:方法区,Heap,堆栈,PC寄存器,Native方法堆栈。
3. 执行引擎。解释器,JIT,垃圾回收器
内存泄漏原因:
1. Open stream
2. Open connections
3. 大量静态变量对象
4. 放入集合的数据,没有覆盖hashcode和equals
四种垃圾回收器:
- Serial, 单线程
- Parallel, 多线程
- Concurrent, CMS。多线程,mark,sweep
- G1,常用于大内存
Concurrent指的是GC循环,Parallel指的是GC算法。
GC roots:
1. 本地变量
2. 活动线程
3. 静态变量
4. JNI引用
从Java8开始,PermGeneration被Metaspace代替。MetaSpace不再是堆内存的一部分。
Heap=YongGen + OldGen = (Eden+S0+S1)+Tenured