java虚拟机运行时数据区域概览

java虚拟机运行时数据区域概览,第1张

java虚拟机运行时数据区域
  • 程序计数器
  • 虚拟机栈
  • 本地方法栈
  • Java堆:也叫(GC堆)
  • 方法区
  • 运行时常量池:(属于方法区)
  • 总结


程序计数器

内存空间比较小的,记录当前线程所执行的字节码的行好指示器,如果虚拟机执行的是java方法,计数器记录的是正在执行的虚拟机字节码的指令地址,如果是native方法,计数器为空,这个区域是不会出现OOM情况的区域–其实就是线程的上下文;是线程私有

虚拟机栈

线程私有,生命周期和线程一样;每个Java方法执行的时候,就会创建一个栈帧存储方法执行需要的变量, *** 作数栈等

描述Java方法执行的线程内存模型,就是Java方法的局部变量和 *** 作符的出入栈,出栈完毕就是方法执行完毕,相当于栈是局部变量区域,堆是全局变量区域

stackOverFlowError申请的栈深度超过虚拟机的深度,OOM是可以动态扩展栈容量的时候,栈扩展的时候申请不到足够的内存(什么时候去扩展,初始栈大小怎么决定的)

hotspot不能动态扩展栈空间,所以OOM出现是在申请的时候在hotpot中

本地方法栈

和虚拟机栈是一样的,区别是执行方法的不同,执行Native方法,Hotspot把本地和虚拟机栈合并,所以本来不会抛OOM和stackoverflow的本地方法栈也会抛出这俩异常了

Java堆:也叫(GC堆)

存放所有的对象实例–唯一目的,按照垃圾收集器划分区域只是主流的设计理念,有的虚拟机没有划分

堆可以实现成固定大小和可扩展,主流的是按照可扩展的来实现,通过-Xmx和Xms设定。如果堆没有内存了,也不能扩展的时候就会抛出OOM

方法区

主要存储已经被虚拟机加载的类型信息,常量,静态变量,即时编译的代码缓存

以前大家喜欢把方法区叫做永久代,永久代只是垃圾回收器把回收范围扩展到了方法区之后,一个技术实现,是为了像管理堆那样管理方法区内存,不用做专门再写一个管理方法区内存的工作

Java8废除了永久代,把方法区的字符串常量池和静态变量等移出到元空间

运行时常量池:(属于方法区)

存放编译期间类生成的各种字面量与符号引用,类加载后存放到方法区的运行时常量池,这个区域具备动态性,运行期间也可以加入新的常量—如果申请不到足够的内存也会抛出OOM

直接内存:不属于虚拟机范畴

堆里面有个DirectByBuffer对象可以作为直接内存的引用 *** 作内存,会出现OOM(设置堆大小的时候忽略直接内存的配置,到时内存区域总和大于物理内存限制,直接内存扩展出现OOM)

总结

对虚拟机运行时区域的主流设计方式总结

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/725788.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-26
下一篇 2022-04-26

发表评论

登录后才能评论

评论列表(0条)

保存