程序计数器:每个线程都需要一个独立的程序计数器
Java虚拟机栈:生命周期与线程相同,(对应一个线程)每个方法在执行的同时都会创建一个栈帧(一个虚拟机栈中包含多个栈帧,对应的是一个线程中包含的多个方法),栈帧中主要存储方法(方法中又包含局部变量,对象引用(不是对象本身,可能是一个指向对象起始地址的引用指针,也可能是指向一个代表对象的句柄或其他与此对象相关的位置),returnAddress类型(指向了一条字节码指令的地址))。
局部变量表所需的内存空间在编译期间完成分配,当进入一个方法时,这个方法需要在帧中分配多大的局部变量空间是确定的,在运行期间不会改变。
在这个内存区域会发生两种异常,StackOverFlowError异常,OutOfMemoryError异常。
本地方法栈:与Java虚拟机栈非常相似,虚拟机栈为虚拟机提供Java方法,而本地方法栈提供Native方法服务。
与Java虚拟机栈一样也会抛出StackOverFlowError异常,OutOfMemoryError异常。
Java堆:是虚拟机所管理的内存中最大的一块。Java堆是被所有线程共享的一块内存区域,在虚拟机启动是创建。几乎所有的对象实例都在这里分配内存。
Java堆是垃圾收集器管理的主要区域,很多时候也被称作“GC堆”。
Java堆物理上可以是不连续的,逻辑上连续即可,一般是可扩展的,当堆无法扩展的时候,会出现OutOfMemoryError异常。
方法区:被多个线程共享,存储虚拟机加载的类信息,常量,静态变量,jishi编译器编译后的代码等数据。很少被垃圾回收器管理,当方法区无法满足内存分配需求时,将抛出OutOfMemoryError异常。
运行时常量池:是方法区的一部分(现在好像放到堆里面,但是好像也不影响什么,上面还有一些虚拟机把方法区和堆当做一个部分,这个先不深究)。用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载后进入方法区的运行时常量池中存放。