JVM-java运行时数据区域详解

java虚拟机在执行java程序的过程中会把他所管理的内存划分为若干个不同的数据区域。这些区域都有各自的用途,以及创建和销毁的时间 ,有的区域随着虚拟机进程的启动而存在,有些区域则以来用户线程的启动和结束建立和销毁。

java虚拟机所管理的内存将会包括以下几个运行时数据区域。

在这里插入图片描述

(图片来源: https://blog.csdn.net/carson0408/article/details/79608686)

程序计数器

程序计数器是一块较小的内存空间,他可以看做是当前线程所执行的字节码的行号指示器。(记录程序执行到哪里了)。
一个处理器(对于多核处理器来说是指 一个内核)都会执行一条线程中的指令。每条线程都需要一个独立的程序计数器,各条线程计数器互不影响,独立储存。

java虚拟机栈

虚拟机栈也是线程私有,他的生命周期与线程相同,每个方法 在执行的同时都会创建一个栈帧用来储存局部变量表、操作数栈、动态链接、方法出口等信息。

我们平常所说的栈就是指的虚拟机栈。

局部变量表存放了编译期可知的各种数据类型(boolean、byte、char、short、int、float、long、double)

本地方法栈

本地方法栈与虚拟机栈的作用非常相似,他们的区别就是虚拟机栈执行java方法,而本地方法栈执行虚拟机用到的Native方法服务。

日常中我们把虚拟机栈和本地方法中合二为一称为栈

java堆

堆是被所有线程共享的一块内存区域,在虚拟机启动时创建。
堆的唯一目的就是存放对象实例。
java堆可以处于物理上不连续的内存空间中。只要逻辑上是连续的即可。

方法区

方法区和java堆一样是各个线程共享的内存区域。他用于储存已被虚拟机加载类的类信息、常量、静态变量、即时编译器编译后的代码数据。

运行时常量池

常量池用于存放编译期生成的各种字面量和符号引用,这部分内容将在类加载后进入方法区的运行时常量池中存放。

执行引擎指的是程序的入口,本地库接口指的是操作系统本身的接口
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值