内网网站建设的步骤过程,做淘宝客网站好搭建吗?,基于html5的旅游网站的设计与实现,自己做网站赚钱目录 1、JVM堆的概念
2、JVM堆的特点
3、JVM堆的内部结构
3.1 组成
3.2 堆内存内部空间所占比例
3.3 永久代和元空间区别
4、堆空间的大小设置
5、堆空间垃圾回收 1、JVM堆的概念
JVM中的堆是用来存放对象的内存空间#xff0c;几乎所有的Java对象、数组都存储在JVM的…
目录 1、JVM堆的概念
2、JVM堆的特点
3、JVM堆的内部结构
3.1 组成
3.2 堆内存内部空间所占比例
3.3 永久代和元空间区别
4、堆空间的大小设置
5、堆空间垃圾回收 1、JVM堆的概念
JVM中的堆是用来存放对象的内存空间几乎所有的Java对象、数组都存储在JVM的堆内存中。比如当我们new一个对象或者创建一个数组的时候就会在堆内存中分配出一段空间用来存放。类加载器读取了类文件后需要把类、方法、常变量放到堆内存中保存所有引用类型的真实信息便于后续的执行。
2、JVM堆的特点 堆内存的存储特点先进先出后进后出 堆是JVM占用区域最大的一块并且在运行时动态地分配内存大小 线程共享整个 Java 虚拟机运行过程中只会有一个堆所有的线程都访问同一个堆。而JVM中的程序计数器、Java 虚拟机栈、本地方法栈都是一个线程对应一个。 虚拟机启动的时候创建堆。 堆是JVM中涉及垃圾回收的主要场所。 堆可分为新生代Eden 区From SurviorTo Survivor、老年代。 JVM规范规定堆可以处于物理上不连续的内存空间中但在逻辑上它应该被视为连续的。 关于 Survivor幸存区 s0s1 区: 复制之后有交换谁空谁是 to。 3、JVM堆的内部结构
3.1 组成
堆内存逻辑上由新生代 ( Young )、老年代 ( Old )、永久代(Perm)组成
新生代 ( Young )包括Eden、From Survivor(From幸存区)和To Survivor(To幸存区)组成。
JDK1.7堆内部组成 JDK1.8 堆内部组成其中永久代(Perm)换成了元空间 堆内存逻辑角度:堆新生代老年代永久代或者元空间
堆内存物理角度由新生代 ( Young )和老年代 ( Old )组成公式如下
堆内存的实际大小新生代的大小老年代的大小
3.2 堆内存内部空间所占比例
新生代与老年代的默认比例 1:2
新生代区的默认比例是 8:1:1
说明在 HotSpot 中Eden 空间和另外两个 SurvIvor 空间缺省所占的比例是 8:1:1
3.3 永久代和元空间区别
永久代使用的是JVM的内存存储字符串和数组容易出现性能和内存溢出问题大小不好指定GC复杂度高。
元空间不再使用JVM的内存而是使用计算机本地内存元空间大小只受本地内存限制。
元空间的设置参数-XX:MetaspaceSize初始值值和-XX:MaxMetaspaceSize最大值
4、堆空间的大小设置
-Xms表示堆区的初始内存等价于 -XX:InitialHeapSize
-Xmx 表示堆区的最大内存等价于 -XX:MaxHeapSize
注意如果堆中的内存大小超过 “-Xmx 所指定的最大内存值的时候将会抛出 OutOfMemoryError 异常。
说明一般情况下会将 -Xms 和 -Xmx 两个参数配置相同的值其目的是为了能够在 java 垃圾回收机制清理完堆区后避免重新分隔计算堆区的大小从而提高性能。
默认情况下
初始内存物理电脑内存大小 / 64
最大内存物理电脑内存大小 / 4
5、堆空间垃圾回收
堆空间的垃圾回收有三种机制MinorGCMajorGCFullGC。
Minor GC清理年轻代内存空间包括 Eden 和 Survivor 区域释放在Eden中所有不活跃的对象释放后若Eden空间还不满足以放入新对象JVM会试图将部分Eden中活跃对象放入Survivor区。Survivor区被用来作为Eden及老年代的中间交换区域如果老年代空间满了Survivor区的对象会被移到老年代否则会被保留在Survivor区。
Major GC清理老年代内存空间当老年代空间不够时JVM会在老年代进行Major GC。
Full GC清理JVM整个堆内存空间包括年轻代和老年代空间。