本文论述的是JDK1.8.0之后的版本。
1.内存
2.新建对象过程
堆的构成:
JVM内存模型
A:程序计数器(program count register)
为线程私有,是一块比较小的内存空间,为当先线程所执行的字节码行号指示器。其指向吓一跳需要执行的字节码指令。该内存不会出现OutOfMemoryError。
B:本地方法栈
为线程私有,JVM需要使用到的Native方法服务。Sun HotSpot直接把本地方法栈和JVM栈合二为一。本地方法栈会抛出StackOverFlowError和OutOfMemoryError。Native Method就是Java调用非Java代码的接口。
C:Java虚拟机栈(Java vitual Machine Stack)
为线程私有,Java栈是Java方法执行的内存模型,栈中存放的是一个个的栈帧,每个栈帧对应一个被调用的方法,在栈帧中包括局部变量表、操作数栈、指向当前方法所属的类的运行常量池、方法返回地址和一些额外的附加信息。
D:方法区(Method )
为各个线程共享,用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据,别名:非堆,永久代。相对而言垃圾收集行为在这个区域比较少出现。当方法区无法满足内存分配需求时,将抛出OutOfMemoryError。
E:堆(Heap)
为线程共享区域,虚拟机所管理的内存中最大的一块。此内存区域的唯一目的是存放对象实例,几乎所有的对象实例都是在这里分配内存。
堆是垃圾收集器管理的主要区域,因为很多时候也被称为GC堆。堆可以细分为:新生代和老年代,新生代可以进一步分为Eden空间、From Survivor空间和To Survivor空间。如果在堆中没有内存完成实例分配,并且也无法再扩展时,将会抛出OutOfMemoryError异常。