JVM之运行时数据区域(堆、栈、方法区、程序计数器)

最近重温”深入理解Java虚拟机”一书,特此记录,最后: 周志明老师牛鼻!

一、 了解

在1995年5月23号,Oak语言改名为Java,并且正式的在SunWorld大会上发布版本(1.0),在此Java也第一次提出了” Write Once,Run Anywhere”(编写一次,到处运行)的口号.
而Java之所以崛起可以,可以说虚拟机(JVM)功不可没, Java的崛起是基于” Write Once,Run Anywhere”,而JVM最初就是服务于Java语言用来实现” Write Once,Run Anywhere”的;
在这里插入图片描述

二、 程序计数器

每个线程都有一个独立的程序计数器,主要用于线程轮流切换时记录本线程执行进度的,等到下次切换到本线程时,会直接从计数器记录的位置开始执行指令(等同于当前线程执行进度的存储节点)

三、 栈

1、 虚拟机栈

和程序计数器一样,每个线程都有一个独立的虚拟机栈,它的生命周期与线程相同。每个方法执行的同时都会创建一个栈帧用于存储局部变量表、操作数栈、动态链接、方法出口等信息,每个方法从调用直至执行完成,对应着一个栈帧在虚拟机栈中入栈到出栈的过程。
我们常说的JVM中的堆、栈中的栈其实就相当于虚拟机栈中局部变量表,局部变量表中存放了编译器可知的各种基本数据类型(boolean、byte、char、int、long等)、对象引用,其中64位长度的long和double类型数据占用2个局部变量空间,而其余数据只占用1个局部变量空间

2、 本地方法栈

本地方法栈与虚拟机的区别只在于:虚拟机栈为虚拟机执行java方法(也就是字节码)服务,而本地方法栈则是为虚拟机使用的的Native方法服务(java中实现编码语言为非java语言的方法,主要为C、C++)。
了解:java的HotSpot虚拟机中 虚拟机栈和本地方法栈是不区分的,合二为一
存储局部变量表、操作数栈、动态链接、方法出口等信息

四、 堆

堆是被所有线程共享的内存区域,是虚拟机管理的内存中最大的一块,在虚拟机启动时创建,唯一作用就是存放对象实例,几乎所有的对象实例以及数组都要在堆上分配,同时堆也是垃圾收集器管理(GC)的主要区域

五、 方法区

方法区与堆一样,是被所有线程共享的内存区域,用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据
字符串常量池:意如其名,jvm中存储字符串常量的池子,唯一且不重复
运行时常量池:class文件中用于存放编译期生成的各种字面量和符号引用中的池子,每个class文件拥有一个独立的运行时常量池

注意:
以上分布都是基于JDK1.7版本的,后续版本有改动!

HotSpot虚拟机JDK1.7之前,运行时常量池包括字符串常量池都存放在方法区,此时方法区的实现为永久代
HotSpot虚拟机JDK1.7时,字符串常量池被存放在堆中,运行时常量池还在方法区,此时方法区的实现依旧为永久代
HotSpot虚拟机JDK1.8时,字符串常量池和运行时常量池和JDK1.7一致,但是方法区的实现由永久代变成了元空间

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值