深入理解jvm:jvm执行时数据区域分类

author author     2022-09-08     714

关键词:

JVM在运行java程序的过程中会把他所管理的内存划分为若干个不同的数据区域。

这些区域都有各自的用途和创建、销毁时间。有些区域随着虚拟机的启动而存在。有些区域则依赖用户线程的启动和结束而建立和销毁。依据《Java虚拟机规范1.7》规定,Java虚拟机所管理的内存分为下面几个区域:
程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区、运行时常量池、直接内存
程序计数器
是一块较小的内存空间。他能够看作是当前线程所运行的字节码的行号指示器。

在虚拟机的概念模型里,字节码解释器工作时就是通过改变这个计数器的值来选取下一条须要运行的字节码指令,分支,循环,跳转,异常处理,线程恢复等基础功能都依靠这个计数器来完毕。


因为Java虚拟机的多线程是通过线程轮流切换并分配处理器运行时间的方式来实现的,在不论什么一个确定的时刻,一个处理器(对于多核处理器仅仅有一个内核)都仅仅会运行一个线程中的指令。

因此,为了线程切换后能恢复到正确的运行位置,每条线程都须要有一个独立的程序计数器。各条线程之间计数器互不影响,独立存储。我们称这类内存区域为“线程私有”内存。


Java虚拟机栈
Java虚拟机栈也是线程私有的。他的生命周期与线程同样。虚拟机栈描写叙述的是Java方法运行的内存模型:每个方法在运行的同一时候都会创建一个栈帧用于存储局部变量表、操作数栈、动态链接、方法出入口等。

每个方法从调用到运行完毕过程。就相应着一个栈帧在虚拟机中入栈到出栈的过程。
常常有人将Java内存分为堆内存(Heap)和栈内存(Stack),这样的分法是比較粗略的,java的内存区域远比这个复杂。
局部变量表存放了编译期可知的各种数据类型(boolean,byte,char,shot,int,float,long,double),对象引用类型(reference类型,他不同于对象本身,可能是一个指向对象起始地址的引用指针。也可能是一个代表对象的句柄或者其它与此对象关联的位置)和returnAddress类型(指向了一条字节码指令的地址)。
当中64位长度的lang和double类型的数据会占用2个局部变量空间(slot),其余数据类型仅仅占用1个。局部变量表所需的内存空间在编译期间完毕分配。当进入一个方法时。这种方法须要在帧中分配多大的局部变量空间是全然确定的。在方法运行期间不会改变局部变量表的大小。


在java虚拟机规范中,对于这个区域规定了两种异常状况:假设线程请求的栈深度大于虚拟机所同意的深度,将抛出StackOverflowException异常;假设虚拟机能够动态扩展。假设扩展到无法申请足够的内存。就会抛出OutMemoryError异常。
本地方法栈
虚拟机栈是为虚拟机运行Java方法也就是字节码服务的。而本地方法栈则为虚拟机用的Native方法服务。与虚拟机栈一样。本地方法栈也会抛出StackOverflowException和OutMemoryError异常。
Java堆
对于大多数应用来说。Java堆是Java虚拟机所管理的内存最大的一块,Java堆是被全部线程共享的一块内存区域,在虚拟机启动时创建。此内存区域的唯一目的就是存放对象实例,差点儿全部的对象实例都要在这里分配内存,全部的对象实例以及数组都要在堆上分配,随着编译器的发展全部的对象都在对上分配变得不是那么绝对了。


Java堆是垃圾收集器管理的主要区域。因此非常多时候被称作GC堆。

从内存回收的角度来看:因为如今收集器基本都採用分代收集算法,所以Java堆还能够细分为:新生代和老年代。再仔细一点有Eden空间、From Survivor空间、To Survivor空间等。从内存的分配角度来看,线程共享的java堆可能划分出多个线程私有的分配缓冲区。

只是不管怎样划分都与存放内容无关。不管哪个区域存储的依旧是实例对象。进一步划分的目的是为了更好的回收内存,或者更快的回收内存。


依据Java虚拟机的规定,Java堆能够处于物理上不连续的内存空间,仅仅要逻辑上连续的就可以。


方法区
方法区与Java堆一样。是各个线程共享的区域,他用于存储已被虚拟机载入的类信息。常量,静态变量。即时编译器编译后的代码等数据。尽管java虚拟机规范把方法区描写叙述为堆的一个逻辑部分,可是他有别名——非堆,为了与java堆区分开来。
对于习惯在Hotspot虚拟机上开发、部署的开发人员来说,非常多人愿意把方法区称为永久代,本质上两者并不等价。

依据java虚拟机规范当方法区无法满足内存分配需求时将抛出OutOfMemoryError异常。
运行时常量池
是方法区的一部分,Class文件除了有类的版本号、字段、方法、接口等描写叙述信息外,另一项信息是常量池,用于存放编译期生成的各种字面量和符号引用,这部分内容将在类载入后进入方法区的运行时常量中存放。

他也是方法区的一部分,无法满足内存分配需求时将抛出OutOfMemoryError异常。
直接内存
不是虚拟机运行时数据区一部分,也不是java虚拟机规范中定义的内存区域。可是这部分内存也被频繁的使用,并且可能导致OutOfMemoryError异常。直接内存的分配不会受到java堆大小的限制,可是,既然是内存。肯定还是会受到本机内存的限制。运维在配置虚拟机參数时,会依据实际内存设置-Xmx等參数信息,但常常忽略直接内存。使得内存区域总和大于物理内存限制,从而导致动态扩展时出现OutOfMemoryError异常。

深入理解jvm虚拟机:java运行时数据区域

概述JVM是Java语言的精髓所在,因为它Java语言实现了跨平台运行,以及自动内存管理机制等,本文将从概念上介绍JVM内存的各个区域,说明个区域的作用。JVM运行时数据区模型Java虚拟机在执行Java程序的过程中会把它所管理的内... 查看详情

深入理解jvm--java内存区域

一. 运行时数据区域  Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域.   Java虚拟机所管理的内存将会包括以下几个运行时数据区域:                &nb... 查看详情

jvm,深入理解java虚拟机,运行时数据区域

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

深入理解jvm的内存区域

深入理解运行时数据区代码示例:1.JVM 向操作系统申请内存:  JVM 第一步就是通过配置参数或者默认配置参数向操作系统申请内存空间,根据内存大小找到具体的内存分配表,然后把内存段的起始地址和终止地址分配... 查看详情

jvm深入理解自动内存分配与垃圾回收

要想了解jvm自动内存分配,首先必须了解jvm的运行时数据区域,否则如何知道在哪里进行自动内存分配,如何进行内存分配,回收哪里的垃圾对象?jvm运行时数据区:程序计数器,虚拟机栈,本地方法栈,方法区,堆程序计数器... 查看详情

深入理解jvm

深入理解JVM原文链接:https://www.cnblogs.com/dingyingsi/p/3760447.html整理:CCSoft 虚拟机内存模型中定义的访问操作如下图所示:图1.JVM虚拟机定义的访问操作java中通过多线程机制使得多个任务同时执行处理,所有的线程共享JVM内存... 查看详情

深入浅出jvm:运行时数据区域

程序计数器线程私有指向了正在执行的虚拟机字节码指令的地址;如果是本地方法,数值为空没有OutOfMemoryError错误的区域Java虚拟机栈线程私有;生命周期与线程相同;代表着Java方法执行的内存模型:每个方法执行时的同时会创... 查看详情

深入理解java内存结构

由于Java程序是交由JVM(Java虚拟机)执行的,所以我们在谈Java内存区域划分的时候事实上是指JVM内存区域划分。一、Java程序执行流程  首先.java文件会被Java编译器编译为.class字节码文件,然后由JVM中的类加载器加载个各类的... 查看详情

java内存区域——深入理解jvm读书笔记

本内容由《深入理解java虚拟机》的部分读书笔记整理而成,本读者计划连载。通过如下图和文字介绍来了解几个运行时数据区的概念。方法区:它是各个线程共享的区域,用于内存已被VM加载的类信息、常量、静态变量、即时编... 查看详情

jvm运行时数据区

引自《深入理解Java虚拟机》前言JVM运行时数据分为几大部分程序计数器Java虚拟机栈本地方法栈Java堆方法区(永久代)运行时常量池直接内存JVM内存区域Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的... 查看详情

jvm,深入理解java虚拟机,运行时数据区域

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

jvm,深入理解java虚拟机,运行时数据区域

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

深入理解java虚拟机

title:深入理解Java虚拟机date:2020-05-1410:58:24tags:JVM,虚拟机目录title:深入理解Java虚拟机date:2020-05-1410:58:24tags:JVM,虚拟机1.运行时数据区域2.GC垃圾回收3.内存分配与回收策略4.类加载机制1.加载2.验证3.准备4.解析5.初始化5.类与类加载器1.... 查看详情

深入理解java虚拟机一java运行时内存区域与class文件

一 JAVA运行时内存区域JVM在加载class文件时,会将class文件定义的数据结构转为运行时内存中的数据,那么jvm是如何安排运行时的内存区域呢?jvm将运行时内存划分为以下几个部分:堆:所有线程共享方法区:类信息、静态变... 查看详情

深入jvm之理解jvm内存区域与对象创建内存布局

写在前面java语言通过IDE的编译生成class文件,然后java虚拟机加载class文件到内存,之后运行在java虚拟机上。在这样的一个宏观的过程中,JVM的内存分区到底是什么样的呢?他们的作用又是什么呢?JVM运行时数... 查看详情

深入理解jvm——java内存区域与内存溢出异常

本文为《深入理解Java虚拟机》第二章内容的学习笔记,部分内容经过二次加工。若对相关知识感兴趣,推荐购书深入阅读。若认为文章涉嫌侵权,请联系作者及时删除。本作品采用知识共享署名-非商业性使用-相同方... 查看详情

jvm(得深入)

一、java运行时数据区域 1、方法区:各个线程共享的内存区域,已加载的类信息、常量、静态变量、即时编译后的代码区域。2、堆:是被所有线程共享的一块内存区域,在虚拟机启动时创建,存放对象的实例。OutOfMemoryError... 查看详情

《深入理解jvm3ed》读书笔记(代码片段)

前言刷豆瓣看到《深入理解JVM》出第三版了,遂买之更新JVM知识,本文为笔记,仅供个人Reviewch02.Java内存区域与内存溢出2.1运行时数据区域参考:JVM规范,MemoriesofaJavaRuntime堆:JVM启动时按-Xmx,-Xms大小创建... 查看详情