JVM03_运行时数据区概述
Posted root_zhb
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JVM03_运行时数据区概述相关的知识,希望对你有一定的参考价值。
1、概述+目录
- 内存是硬盘和CPU的中间仓库和桥梁。
- 不同的JVM对于内存的划分方式和管理机制存在部分差异(典型:方法区)
一份JVM对应一个Runtime类实例,对应一份运行时数据区。
2、共享或私有
- 多线程共享:方法区和堆
- 单个线程私有:PC寄存器(程序计数器)、虚拟机栈、本地方法栈
3、GC和OOM
- PC寄存器既无GC,也无OOM
- 栈无GC,可能OOM
- 堆、方法区有GC,可能OOM
4、两个问题
-
为什么栈不用垃圾回收器回收?
虚拟机栈里的栈帧即对应代码中的一个方法。代码运行的过程,即栈帧入栈出栈的过程。
一个方法执行完,栈帧出栈后,即被销毁。只有入栈出栈这样简单的操作,不需要设计复杂的垃圾回收算法来回收。随着方法的执行,线程的结束正常回收即可。
在递归函数中,该方法还没有结束,就一直不会出栈,如果循环的次数过多,栈空间有被挤爆的可能。会出现StackOverflowError 栈溢出。栈溢出也是内存溢出的一种情况。可通过-Xss (stack size)设置栈大小。
-
为什么程序计数器没有OOM?
程序计数器(Program Counter Register)也称PC寄存器。是运行时数据区里唯一一块没有Out of Memory的区域。
只存下一个字节码指令的地址,消耗内存小且固定,无论方法多深,他只存一条。
只针对一个线程,随着线程的结束而销毁。
以上是关于JVM03_运行时数据区概述的主要内容,如果未能解决你的问题,请参考以下文章