运行时数据区域

本文介绍内容如下: 一、运行时数据区域 二、各运行时数据区域特点 一、运行时数据区域 (1)线程共享:堆、方法区 (2)线程隔离:程序计数器、虚拟机栈、本地方法栈 二、各运行时数...

本文介绍内容如下:

一、运行时数据区域

二、各运行时数据区域特点

一、运行时数据区域

(1)线程共享:堆、方法区

(2)线程隔离:程序计数器、虚拟机栈、本地方法栈

二、各运行时数据区域特点

1、程序计数器

 (1)特点:

1⃣️程序计数器是一块较小的内存,可当作线程执行字节码的行号指示器;

2⃣️虚拟机概念模型,字节码解释器的工作通过改变计数器的值来选取下一条需要执行的字节码指令,分之、循环、跳转、异常处理、线程恢复等基础功能;

3⃣️线程切换后能恢复到正确的执行位置,每条线程都需要一个独立的程序计数器,各线程间计数器互不影响,独立存储

4⃣️此区域是唯一一个在Java虚拟机规范中没有规定任何OOM的区域

2、虚拟机栈

(1)特点

1⃣️虚拟机栈线程私有,它的生命周期与线程相同

2⃣️描述方法的执行的内存模型:每个方法在执行的同时都会创建一个栈帧,用于存储局部变量表、操作数栈、动态链接、方法出口信息。方法执行完成,对应一个栈帧在虚拟机中入栈到出栈过程

3⃣️StackOverflowError:线程请求的栈深度大于虚拟机所允许的深度抛出该异常

     OOM:如果虚拟机可以动态扩展,扩展时无法申请到足够的内存

3、虚拟机栈

与本地方法栈作用类似,虚拟机栈为虚拟机执行Java方法,本地方法栈则为虚拟机执行native方法服务。

4、堆

(1)特点:
1⃣️堆为线程共享的内存区域,虚拟机启动时创建;

2⃣️堆区域的唯一目的是为了存放对象的实例

3⃣️堆是垃圾收集器管理的主要区域,也被称为GC堆

4⃣️堆可细分为:新生代,老年代,再细致一点为eden,From Survivor,To Survivor.

5⃣️Java堆可以处于物理上不连续的内存空间,只要逻辑上连续即可

6⃣️如果堆中没有内存完成实例分配,并且也无法再扩展时,会抛出OOM

5、方法区

(1)特点:

1⃣️线程共享,用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码数据,别名“非堆”

(2)运行时常量池

1⃣️方法区的一部分,Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息时常量池,用于存放编译期生成的各种字面量和符号引用,这部分内容在类加载后进入方法区运行时常量池;

2⃣️运行常量池具备动态性,并非预置入class文件中常量池的内容才能进入运行时常量池,利用String intern()方法运行期间可将新常量放入

3⃣️常量池无法再申请到内存时,会抛出OOM

(3)直接内存

1⃣️不是虚拟机运行时数据区域的一部分,也不是Java虚拟机规范中定义的内存区域,但是频繁被使用,也有可能导致OOM

  • 发表于 2019-09-18 15:41
  • 阅读 ( 115 )
  • 分类:网络文章

条评论

请先 登录 后评论
不写代码的码农
小编

篇文章

作家榜 »

  1. 小编 文章
返回顶部
部分文章转自于网络,若有侵权请联系我们删除