首页 > 技术文章 > java虚拟机内存模型

andyyang1013 2020-05-12 17:55 原文

Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域。

这些区域都有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有些区域则是依赖用户线程的启动和结束而建立和销毁。

Java虚拟机所管理的内存将会包括以下几个运行时数据区域:Method Area(方法区),VM Stack(虚拟机栈),Native Method Stack(本地方法栈),Heap(堆),Program Counter Register(程序计数器)。

 

Method Area

  • 生命周期:Java虚拟机进程的启动与关闭
  • 存储内容:类信息,常量,静态变量,即时编译器编译的字节码
  • 存储内容是线程共享的

 

VM Stack

  • 生命周期:用户线程的启动与关闭
  • 存储内容:局部变量表,操作栈,动态链接,方法出口
  • 存储内容是线程独享的

 

Native Method Stack与VM Stack相似,只是只与Native方法相关

 

Heap

  • 生命周期:Java虚拟机进程的启动与关闭
  • 存储内容:对象实例,数组
  • 存储内容是线程共享的

 

Program Counter Register

  • 生命周期:用户线程的启动与关闭
  • 存储内容:字节码执行记录
  • 存储内容是线程独享的

推荐阅读