JVM总结--1

Java内存区域
java虚拟机管理锁管理的没存分为如下区域:
这里写图片描述
具体如下:
1.程序计数器:
是一块较小的内存空间 可以当作是当前线程所执行的字节码的行号指示器。在虚拟机的概念模型里,字节码解释器工作就是通过改变这个计数器的值来选取下一条需要执行的字节码指令。分支,跳转,循环,异常处理。线程恢复等基础功能都需要依赖这个计数器来完成。
程序计数器是每个线程私有内存:由于Java虚拟机的多线程是通过线程轮流切换分配处理器执行时间来实现。也就是说在任一确定的时刻,一个处理器都只会执行一条线程的执行,因此为了能回复到原来的正确执行位置,所以程序计数器是私有的。
同时也是唯一一个在Java规范中没有规定任何OutOfMemoryError情况的区域。
2.Java虚拟机栈
也是线程私有的,生命周期同线程。虚拟机栈描述的是Java方法执行的内训模型:每个方法在执行的同时都会创建一个栈帧,用于存放局部变量表,动态链接,操作数栈,方法出口等信息。
对于平常说的堆内存和栈内存,是比较粗糙的分法,实际上更加复杂,这里说的“栈”讲的是虚拟机栈或者是虚拟机栈中的局部变量表部分。
局部变量表存的是编译期可知的基本数据类型,对象引用,returnAddress地址
虚拟机栈的异常分为两种情况:1.如何线程请求的栈深度大于虚拟机允许的深度,则抛出StackOverFlowError异常。2.如果虚拟机可以东爱扩展(当前大部分虚拟机都可以),如果扩展时无法申请到足够的地址空间,则抛出OutOfMemoryError
3.本地方法栈:
本地方法栈与虚拟机栈发挥的作用非常相似,虚拟机栈为虚拟机执行Java方法的服务。本地方法栈为虚拟机使用到的native方法服务。
有的虚拟机本地方法栈和虚拟机栈是分开的,但有的虚拟机是将二者合在一起的(Sun HotSpot),与虚拟机栈一样本地方法栈也会抛出OutOfMemoryError和StackOverFlowError
4.java堆:
Java堆是Java虚拟机所管理的最大一块内存,是被所有线程共享的,在虚拟机启动时创建。其存放的内容也就是我们创建的实例对象和数组。
Java堆时垃圾收集器管理的主要区域,因此很多时候可称为GC堆。从内存回收角度来看,由于现代收集器基本上时采用分代收集算法,所以Java堆还可以细分为:新生代和老年代
Java虚拟机规范规定,Java堆可以处在非连续的物理空间上,只要逻辑上连续即可。在实现时,既可以固定大小,也可以是可扩展的(通过-Xmx和-Xms来控制)。当在堆中没有内存完成实例分配,并且堆也无法扩展时,就会抛出OutOfMemoryError。
5.方法区:
和Java堆一样时所有线程共享的内存区域。其存放已被虚拟机加载的类信息,常量,静态变量(对象类型数据),即时编译器编译的代码等数据。
在HotSpot虚拟机上,很多人称方法区被称为“永久代”,本质上两者不等价,仅仅是因为HotSpot开发者团队将GC分代收集扩展到方法区。HotSpot垃圾收集器可以像Java堆一样管理方法区。
Java虚拟机规范规定,当方法区无法满足内存需求时,将抛出OutOfMemoryError。
6.运行时常量池:
其是方法区的一部分。Class文件中除了有类的版本,字段,方法,接口等描述信息外,还有一项信息是常量池,用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载后存放在运行时常量池中。
由于是方法区的一部分,所以,当常量池无法在申请到内存时,将抛出OutOfMemoryError

猜你喜欢

转载自blog.csdn.net/qq_41056506/article/details/81708853
今日推荐