堆的核心概述
- 一个JVM实例只存在一个堆内存,堆是Java内存管理的核心区域
- Java堆在JVM启动时被创建,大小也被确定。是JVM管理的最大一块内存空间,大小可调节
- JVM规范规定堆可以在物理上不连续的内存空间中,但逻辑上要连续
- 所有线程共享Java堆,在这里还划分线程私有的缓冲区(Thread Local Allocation Buffer,TLAB)
- JVM规范规定几乎所有对象实例以及数组都应在运行时分配到堆上
- 数组和对象可能远远不会存储在栈上,因为栈帧中保存引用,这个引用执行对象或者数组在堆中引用
- 在方法结束后,堆中的对象不会马上被移除,仅仅在垃圾收集的时候才会被移除
- 堆是GC执行垃圾回收的重点区域
package chapter08;
public class SimpleHeap {
private int id;
public SimpleHeap(int id) {
this.id = id;
}
public void show(){
System.out.println("My id is :" + id);
}
public static void main(String[] args) {
SimpleHeap s1 = new SimpleHeap(1);
SimpleHeap s2 = new SimpleHeap(2);
}
}
堆:内存细分
现代垃圾收集器大部分都是基于分代垃圾收集理论,堆空间细分为
- java7 逻辑上 新生区 + 养老区 + 永久区
- java8 逻辑上 新生区 + 养老区 + 元空间
设置堆大小和OOM
-Xms:设置堆区(新生代+养老代)的起始内存,等价于-XX:InitialHeapSize
- -X:jvm的运行参数
- ms:memory start
-Xmx:设置堆区的最大内存,等价于-XX:MaxHeapSize
默认堆空间大小:
- 初始内存:物理电脑内存大小/64
- 最大内存:物理电脑内存大小/4
package chapter08;
public class HeapSpaceInitial {
public static void main(String[] args) {
long initialMemory = Runtime.getRuntime().totalMemory() /1024 /1024;
long maxMemory = Runtime.getRuntime().maxMemory() /1024 / 1024;
System.out