JVM的简化架构

内容纲要

运行时数据区

  • 包括:PC寄存器(程序计数器)、Java虚拟机栈、Java堆、方法区、运行时常量池、本地方法栈等

PC寄存器

PC ( Program Counter )寄存器说明:

  1. 每个线程拥有一-个PC寄存器,是线程私有的,用来存储指向下一条指令的地址
  2. 在创建线程的时候,创建相应的PC寄存器
  3. 执行本地方法时, PC寄存器的值为undefined
  4. 是一块较小的内存空间,是唯一一 个在JVM规范中没有规定OutOfMemoryError的内存区域(这块区域不会溢出)

Java栈

  • 栈由一系列帧( Frame )组成(因此Java栈也叫做帧栈),是线程私有的
  • 帧用来保存一个方法的局部变量、操作数栈( Java没有寄存器,所有参数传递使用操作数栈)、常量池指针、动态链接、方法返回值等
  • 每一-次方法调用创建一 个帧,并压栈,退出方法的时候,修改栈顶指针就可以把栈帧中的内容销毁
  • 局部变量表存放了编译期可知的各种基本数据类型和引|用类型,每个slot存放32位的数据,long、double占 两个槽位
  • 栈的优点:存取速度比堆快,仅次于寄存器
  • 栈的缺点:存在栈中的数据大小、生存期是在编译期决定的缺乏灵活性

Java堆

  • 用来存放应用系统创建(new出来的对象)的对象和数组, 所有线程共享Java堆
  • GC主要就管理堆空间,对分代GC来说,堆也是分代的
  • 堆的优点:运行期动态分配内存大小,自动进行垃圾回收;
  • 堆的缺点:效率相对较慢(相对于栈)

方法区

  • 方法区是线程共享的,通常用来保存装载的类的结构信息
  • 通常和元空间关联在一起,但具体的跟JVM实现和版本有关
  • JVM规范把方法区描述为堆的一个逻辑部分,但它有一个别名称为Non-heap (非堆) , 应是为了与Java堆区分开

运行时常量池

  • 是Class文件中每个类或接口的常量池表,在运行期间的表示形式,通常包括:类的版本、字段、方法、接口等信息
  • 方法区中分配
  • 通常在加载类和接口到JVM后,就创建相应的运行时常量池

本地方法栈

  • 在JVM中用来支持native方法执行的栈就是本地方法栈

栈、堆、方法区交换关系

THE END
分享
二维码
< <上一篇
下一篇>>