目录
一、堆
二、堆的内存细分
一、堆
1、一个JVM实例只存在一个堆内存,堆也是Java内存管理的核心区域。
2、Java堆区在JVM启动的时候即被创建,其空间大小也就确定了。是JVM管理的最大一块内存空间。堆内存的大小是可以调节的。
参考代码:
public class HeapDemo {
public static void main(String[] args) {
System.out.println("开始。。。");
try {
Thread.sleep(1000000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("结束。。。");
}
}
public class HeapDemo1 {
public static void main(String[] args) {
System.out.println("开始。。。");
try {
Thread.sleep(1000000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("结束。。。");
}
}
设置不同的参数:
指令:-Xms10m -Xmx10m
运行程序。使用Java自带jvisualvm.exe观察。
3、《Java虚拟机规范》规定,堆可以处于物理上不连续的内存空间中,但在逻辑上它应该被视为连续的。
4、所有的线程共享Java堆,在这里还可以划分线程私有的缓冲区 (Thread Local Allocation Buffer,TLAB)。
5、《Java虚拟机规范》中对Java堆的描述是:所有的对象实例以及数组都应当在运行时分配在堆上。(The heap is the run-time data area from which memory for all class instances and arrays 1s aiiocaleu )“几乎”所有的对象实例都在这里分配内存。—从实际使用角度看的。
6、数组和对象可能永远不会存储在栈上,因为栈帧中保存引用,这个引用指向对象或者数组在堆中的位置。
7、在方法结束后,堆中的对象不会马上被移除,仅仅在垃圾收集的时候才会被移除。
8、堆,是GC ( Garbage collection,垃圾收集器)执行垃圾回收的重点区域。
参考代码:
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);
int[] arr = new int[10];
Object[] arr1 = new Object[10];
}
}
二、堆的内存细分
现代垃圾收集器大部分都基于分代收集理论设计,堆空间细分为:
这里主要区别在于jdk8以前是新生区、养老区、永久区。jdk8即以后使用元空间代替了永久区。
jdk7的堆内部空间:
设置参数:-Xms10m -Xmx10m -XX:+PrintGCDetails 打印垃圾回收细节
打印信息: