一、JVM概述
JVM (JAVA 虚拟机),定义了一套编译,加载,解释执行JAVA代码的规范,
基于这套规范市场上不同产品实现,例如Hotspot,JRockit,J9等.
其简易内存体系结构如下:
二、堆的内存划分:
Java堆的内存划分如图所示,分别为年轻代、Old Memory(老年代)、Perm(永久代)。其中在Jdk1.8中,永久代被移除,使用MetaSpace代替。
1、新生代:
-
(1)使用复制清除算法(Copinng算法),原因是年轻代每次GC都要回收大部分对象。新生代里面分成一份较大的Eden空间和两份较小的Survivor空间。每次只使用Eden和其中一块Survivor空间,然后垃圾回收的时候,把存活对象放到未使用的Survivor(划分出from、to)空间中,清空Eden和刚才使用过的Survivor空间。
-
(2)分为Eden、Survivor From、Survivor To,比例默认为8:1:1
-
(3)内存不足时发生Minor GC
2、老年代:
-
(1)采用标记-整理算法(mark-compact),原因是老年代每次GC只会回收少部分对象。
3、Perm:用来存储类的元数据,也就是方法区。
-
(1)Perm的废除:在jdk1.8中,Perm被替换成MetaSpace,MetaSpace存放在本地内存中。原因是永久代进场内存不够用,或者发生内存泄漏。
-
(2)MetaSpace(元空间):元空间的本质和永久代类似,都是对JVM规范中方法区的实现。不过元空间与永久代之间最大的区别在于:元空间并不在虚拟机中,而是使用本地内存。
三、GC垃圾回收:
常见的垃圾回收算法:
1、Mark-Sweep(标记-清除算法):
-
(1