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、两个问题

  1. 为什么栈不用垃圾回收器回收?

    虚拟机栈里的栈帧即对应代码中的一个方法。代码运行的过程,即栈帧入栈出栈的过程。

    一个方法执行完,栈帧出栈后,即被销毁。只有入栈出栈这样简单的操作,不需要设计复杂的垃圾回收算法来回收。随着方法的执行,线程的结束正常回收即可。

    在递归函数中,该方法还没有结束,就一直不会出栈,如果循环的次数过多,栈空间有被挤爆的可能。会出现StackOverflowError 栈溢出。栈溢出也是内存溢出的一种情况。可通过-Xss (stack size)设置栈大小。

  2. 为什么程序计数器没有OOM?

    程序计数器(Program Counter Register)也称PC寄存器。是运行时数据区里唯一一块没有Out of Memory的区域。

    只存下一个字节码指令的地址,消耗内存小且固定,无论方法多深,他只存一条。

    只针对一个线程,随着线程的结束而销毁。

以上是关于JVM03_运行时数据区概述的主要内容,如果未能解决你的问题,请参考以下文章

JVM_03 运行时数据区1-[程序寄存器+虚拟机栈+本地方法栈]

JVM_05 运行时数据区2-堆

JVM运行时数据区的概述,线程概述

JVM学习笔记二:运行时数据区概述及JVM线程

JVM 专题六:运行时数据区概述

JVM学习--JVM运行时数据区图文详解