概述
JVM 的内存区域可以分为两类:
- 线程私有的区域:程序计数器、JVM 虚拟机栈、本地方法栈。
- 程序计数器。 每个线程有有一个私有的程序计数器,任何时间一个线程都只会有一个方法正在执 行,也就是所谓的当前方法。程序计数器存放的就是这个当前方法的JVM指令地址。
- JVM虚拟机栈。 创建线程的时候会创建线程内的虚拟机栈,栈中存放着一个个的栈帧,对应着一个 个方法的调用。JVM 虚拟机栈有两种操作,分别是压栈和出站。栈帧中存放着局部变量表、方法返 回值和方法的正常或异常退出的定义等等。
- 本地方法栈。 跟 JVM 虚拟机栈比较类似,只不过它支持的是 Native 方法。
- 线程共有的区域:堆、方法区、运行时常量池。
- 堆。堆是内存管理的核心区域,用来存放对象实例。几乎所有创建的对象实例都会直接分配到堆上。所以堆也是垃圾回收的主要区域,垃圾收集器会对堆有着更细的划分,最常⻅的就是把堆划分为新生代和老年代。
- 方法区。方法区主要存放类的结构信息,比如静态属性和方法等等。
- 运行时常量池。运行时常量池位于方法区中,主要存放各种常量信息。
其实除了程序计数器,其他的部分都会发生 OOM。
- 堆。 通常发生的 OOM 都会发生在堆中,最常⻅的可能导致 OOM 的原因就是内存泄漏。
- JVM虚拟机栈和本地方法栈。 当我们写一个递归方法,这个递归方法没有循环终止条件,最终会导 致 StackOverflow 的错误。当然,如果栈空间扩展失败,也是会发生 OOM 的。
- 方法区。方法区现在基本上不太会发生 OOM,但在早期内存中加载的类信息过多的情况下也是会发生OOM 的。
最后
以上就是土豪摩托为你收集整理的JVM内存区域的划分,哪些区域会发生OOM的全部内容,希望文章能够帮你解决JVM内存区域的划分,哪些区域会发生OOM所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复