前言
本次讲述jvm分代模型的基础概念,这个专栏会由浅入深的不断构建起来,循序渐进,是非常基础的内容
概述:
- 讲述JVM的基础分代模型以及版本升级的处理。
- 对象分配的基础概念和知识。
- 长期存活的对象是如何躲过垃圾回收进入到老年代
- jvm内存的核心参数解释以及基础配置
JVM的分代模型
JVM的基础分代模型:年轻代,老年代,永久代。这里需要注意内存模型通常是和垃圾回收期相辅相成的,现代的垃圾收集器已经十分复杂了,甚至已经没有了分代的概念,我们所讲的新生代老年代是最初设计的一些理念,很多人学到更为先进的垃圾收集器可能会蒙蔽,比如堆内存怎么变成一块一块的了,以前不是说堆内存只有新生代和老年代这两块完整大的空间呢?
-
年轻代:大部分的对象都是朝生夕灭的。同时JVM总是把对象优先分配在新生代,并且新生代触发的垃圾回收通常被称为 Minor GC。
-
老年代:属于长期存活的对象贮存地区,由新生代晋升而来。老年代在通常情况下占有堆中最大的一块内存空间。老年代触发的垃圾回收通常被称为 Full GC。
-
永久代:注意永久代不等同于方法区,主要存放一些静态常量或者存放.class类信息,方法区是可以被垃圾回收的,但是触发的条件十分苛刻,同时里面最常用的常量池已经在JDK8之后挪到了堆中,将永久代并且改名为元空间
为什么要把永久代拉进来讲呢?其实永久代的设计是一个失败的设计,JDK8废弃永久代同时用使用本地内存的元空间来替代,大大减少了永久代溢出的可能,因为已经不使用虚拟机的内存了,而是直接使用本机的内存存储,还有一个好处是永久代也不会再去抢堆内存了。
对象分配的基础了解
下面基础了解一下对象分配的基础概念,这些概念可能在学习JAVA的时候就已经接触过了,所以也都是简单提一下:
-
大部分正常对象优先在新生代分配。在垃圾回收线程开启之后,会将长期存活对象晋升到老年代存储
-
即使是静态变量存在于方法区当中的对象,实例对象也是在堆中分配。但是只有被栈帧局部变量使用的时候才会触发初始化。
-
在堆上分配的依然优先选择在新生代分配,当长期