JVM内存模型(通俗易懂)-程序员宅基地

技术标签: zj  jvm  

1.什么是jvm?
(1)jvm是一种用于计算设备的规范,它是一个虚构出来的机器,是通过在实际的计算机上仿真模拟各种功能实现的。
(2)jvm包含一套字节码指令集,一组寄存器,一个栈,一个垃圾回收堆和一个存储方法域。
(3)JVM屏蔽了与具体操作系统平台相关的信息,使Java程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行。
JVM在执行字节码时,实际上最终还是把字节码解释成具体平台上的机器指令执行。

2.jdk、jre、jvm是什么关系?
(1)JRE(Java Runtime Environment),也就是java平台。所有的java程序都要在JRE环境下才能运行。
(2)JDK(Java Development Kit),是开发者用来编译、调试程序用的开发包。JDK也是JAVA程序需要在JRE上运行。
(3)JVM(Java Virtual Machine),是JRE的一部分。它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的。
JVM有自己完善的硬件架构,如处理器、堆栈、寄存器等,还具有相应的指令系统。
Java语言最重要的特点就是跨平台运行。使用JVM就是为了支持与操作系统无关,实现跨平台。

3.JVM原理
(1)jvm是java的核心和基础,在java编译器和os平台之间的虚拟处理器,可在上面执行字节码程序。
(2)java编译器只要面向jvm,生成jvm能理解的字节码文件。java源文件经编译成字节码程序,通过jvm将每条指令翻译成不同的机器码
,通过特定平台运行。

4. JVM执行程序的过程

  1. 加载.class文件
  2. 管理并分配内存
  3. 执行垃圾收集
    JRE(java运行时环境)由JVM构造的java程序的运行环,也是Java程序运行的环境,但是他同时一个操作系统的一个应用程序一个进程,
    因此他也有他自己的运行的生命周期,也有自己的代码和数据空间。
    JVM在整个jdk中处于最底层,负责于操作系统的交互,用来屏蔽操作系统环境,
    提供一个完整的Java运行环境,因此也就虚拟计算机。

操作系统装入JVM是通过jdk中Java.exe来完成,
通过下面4步来完成JVM环境:

  1. 创建JVM装载环境和配置
  2. 装载JVM.dll
  3. 初始化JVM.dll并挂界到JNIENV(JNI调用接口)实例
  4. 调用JNIEnv实例装载并处理class类。

5. JVM的生命周期

  1. JVM实例对应了一个独立运行的java程序它是进程级别
    a) 启动。启动一个Java程序时,一个JVM实例就产生了,任何一个拥有public static void
    main(String[] args)函数的class都可以作为JVM实例运行的起点
    b) 运行。main()作为该程序初始线程的起点,任何其他线程均由该线程启动。JVM内部有两种线程:守护线程和非守护线程,main()属于非守护线程,守护线程通常由JVM自己使用,java程序也可以表明自己创建的线程是守护线程
    c) 消亡。当程序中的所有非守护线程都终止时,JVM才退出;若安全管理器允许,程序也可以使用Runtime类或者System.exit()来退出
  2. JVM执行引擎实例则对应了属于用户运行程序的线程它是线程级别的

6、JVM内存模型

(1)java代码具体执行过程如下图,

(2)运行时数据区,即jvm内存结构图如下图

(3)运行时数据区存储了哪些数据?

a) 程序计数器(PC寄存器)

由于在JVM中,多线程是通过线程轮流切换来获得CPU执行时间的,因此,在任一具体时刻,一个CPU的内核只会执行一条线程中的指令,

因此,为了能够使得每个线程都在线程切换后能够恢复在切 换 之前的程序执行位置,每个线程都需要有自己独立的程序计数器,并且不能互相被干扰,

否则就会影响到程序的正常执行次序。因此,可以这么说,程序计数器是每个线程所私有的。由于程序计数器中存储的数据所占空间的大小不会随程序的执行而发生改变,

因此,对于程序计数器是不会发生内存溢出现象(OutOfMemory)的。

b) java栈

Java栈中存放的是一个个的栈帧,每个栈帧对应一个被调用的方法,在栈帧中包括局部变量表(Local Variables)操作数栈(Operand Stack)

指向当前方法所属的类的运行时常量池(运行时常量池的概念在方法区部分会谈到)的引用(Reference to runtime constant pool)、

**方法返回地址(Return Address)**和一些额外的附加信息。当线程执行一个方法时,就会随之创建一个对应的栈帧,并将建立的栈帧压栈。当方法执行完毕之后,便会将栈帧出栈。

c)本地方法栈

本地方法栈与Java栈的作用和原理非常相似。区别只不过是Java栈是为执行Java方法服务的,而本地方法栈则是为执行本地方法(Native Method)服务的

d)堆

Java中的堆是用来存储对象本身的以及数组(数组引用是存放在Java栈中的)。堆是被所有线程共享的,在JVM中只有一个堆。

e)方法区

与堆一样,是被线程共享的区域。在方法区中,存储了每个类的信息(包括类的名称、方法信息、字段信息)、静态变量、常量以及编译器编译后的代码等。

在Class文件中除了类的字段、方法、接口等描述信息外,还有一项信息是常量池,用来存储编译期间生成的字面量和符号引用。

在方法区中有一个非常重要的部分就是运行时常量池,它是每一个类或接口的常量池的运行时表示形式,在类和接口被加载到JVM后,

对应的运行时常量池就被创建出来。当然并非Class文件常量池中的内容才能进入运行时常量池,在运行期间也可将新的常量放入运行时常量池中,比如String的intern方法。

7、JVM内存溢出的情况

a) 程序计数器(Program Counter Register)

每条线程都有一个独立的的程序计数器,各线程间的计数器互不影响,因此该区域是线程私有的。该内存区域是唯一一个在Java虚拟机规范中没有规定任何OOM(内存溢出:OutOfMemoryError)情况的区域。

b)Java虚拟机栈(Java Virtual Machine Stacks)

在Java虚拟机规范中,对这个区域规定了两种异常情况:

1、如果线程请求的栈深度大于虚拟机所允许的深度,将抛出StackOverflowError异常。

  2、如果虚拟机在动态扩展栈时无法申请到足够的内存空间,则抛出OutOfMemoryError异常。

       这两种情况存在着一些互相重叠的地方:当栈空间无法继续分配时,到底是内存太小,还是已使用的栈空间太大,其本质上只是对同一件事情的两种描述而已。

在单线程的操作中,无论是由于栈帧太大,还是虚拟机栈空间太小,当栈空间无法分配时,虚拟机抛出的都是StackOverflowError异常,而不会得到OutOfMemoryError异常。

而在多线程环境下,则会抛出OutOfMemoryError异常。

c)堆Java Heap

Java Heap是Java虚拟机所管理的内存中最大的一块,它是所有线程共享的一块内存区域。几乎所有的对象实例和数组都在这类分配内存。Java Heap是垃圾收集器管理的主要区域,因此很多时候也被称为“GC堆”。

  根据Java虚拟机规范的规定,Java堆可以处在物理上不连续的内存空间中,只要逻辑上是连续的即可。如果在堆中没有内存可分配时,并且堆也无法扩展时,将会抛出OutOfMemoryError异常。   

d)方法区域,又被称为“永久代”,当方法区无法满足内存分配需求时,将抛出OutOfMemoryError异常。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_36704549/article/details/109390566

智能推荐

gossip-程序员宅基地

文章浏览阅读55次。celebrity ----a famous peopleobama ---- politicatonobject ----反对转载于:https://www.cnblogs.com/shenfengok/archive/2012/07/11/2586893.html

在linux中使用setns()设置pid namespace-程序员宅基地

文章浏览阅读3.1k次。以下代码展示了 setns() 的用法,#define _GNU_SOURCE#include <fcntl.h>#include <sched.h>#include <unistd.h>#include <stdlib.h>#include <stdio.h>#include <string.h>#include <sys/types.h>#include <sys/wait.h>#in_setns

可逆矩阵性质总结_线性代数下的行列式和矩阵-程序员宅基地

文章浏览阅读5.7k次。实际意义求线性方程组线性方程组一般有 m 个常数项,n 个未知数,m * n 个系数。若常数项全为 0 ,则为齐次线性方程组;若未知数全为 0 ,则称为零解。于是我们考虑的问题是:齐次方程组:是否存在非零解,以及存在的条件通解的结构与性质解法非齐次方程组:是否有解,以及有解的条件是什么有多少解以及对应解数量的条件是什么多解的结构与性质解法行列式二,三阶行列式行列式最初的作用就是求解线性方程组!例如..._可逆矩阵一定是实数矩阵吗

centos8的80端口不通问题记录_为什么keepalived连不上本地的80端口-程序员宅基地

文章浏览阅读5.2k次。1、首先是安装了nginx并启动了服务,查看80端口正常listening2、通过其他机器访问网页无法连接,查看telnet到80端口也不通。初步怀疑跟防火墙有关3、查看iptables,发现有部分默认规则,但都是accept。默认的filter表也都是accept,尝试用iptables -F清空规则表后问题依旧4、之前使用的是ubuntu系统,主要通过的就是iptables来控制..._为什么keepalived连不上本地的80端口

Mysql5.7安装 Gtid原理作用+主从复制_gtid在主从复制的作用-程序员宅基地

文章浏览阅读1.3k次,点赞4次,收藏3次。Gtid的作用Gtid,采用了新的复制协议,旧协议是,首先从服务器上在一个特定的偏移量位置连接到主服务器上一个给定的二进制日志文件,然后主服务器再从给定的连接点开始发送所有的事件。新协议有所不同,支持以全局统一事务ID(GTID)为基础的复制。当在主库上提交事务或者被从库应用时,可以定位和追踪每一个事务。GTID复制是全部以事务为基础,使得检查主从一致性变得非常简单。如果所有主库上提交的事务也同样提交到从库上,一致性就得到了保证。Gtid的工作原理1.当一个事务在主库端执行并提交时,产生GTID,一_gtid在主从复制的作用

Java 单例模式浅析_单例模式论文-程序员宅基地

文章浏览阅读229次。提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言一、pandas是什么?二、使用步骤1.引入库2.读入数据总结前言提示:这里可以添加本文要记录的大概内容:例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。提示:以下是本篇文章正文内容,下面案例可供参考一、pandas是什么?示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。二、使用步骤1.引入库代码_单例模式论文

随便推点

安装caffe过程中出现libtbb.so.2 undefined reference error_//usr/lib/x86_64-linux-gnu/libtbb.so.2:对‘__cxa_ini-程序员宅基地

文章浏览阅读768次。caffe 包是从caffe的github官网上下载的https://github.com/BVLC/caffe我是准备安装openpose的,之后按照网上的流程来,可是不管怎么安装依赖项以及修改make.config都卡在最后了[ 4%] Building CXX object src/caffe/CMakeFiles/caffe.dir/util/blocking_queue.cpp.o[ 5%] Linking CXX shared library ../../lib/lib_//usr/lib/x86_64-linux-gnu/libtbb.so.2:对‘__cxa_init_primary_exception@cxxa

会议室电脑怎么无线投屏_会议室无线投屏-程序员宅基地

文章浏览阅读1k次。会议室电脑怎么无线投屏?尤其是远程会议电脑如何无线投屏,可能觉得市场上多如牛毛的投屏器就可以解决这个问题。事实上,投屏器真的可以做到无线投屏电脑吗?一些企业需要召开远程会议,这样可以节省会议成本。演示的会议内容需要多地同屏,比如政府部门,银行等分支机构较多的单位,投屏器是否有这么庞大的数据传输能力;应用开发团队,需要轮流切换不同的电脑和连接设备,接口和分辨率等兼容问题,要反复调试严重影响会议进度;做产品设计演示时让团队成员可以更直观地看到设计稿。这些小问题是企业协同办公中不可忽视的痛点,部署连通宝多屏互_会议室无线投屏

JavaScript绑定this-程序员宅基地

文章浏览阅读42次。问题描述var a = { one: 1, haha() { console.log(this.one) }}setTimeout(a.haha, 1000)在上例中,函数haha引用了this.one,而定时器结束之后调用的haha传入的this并不是a,输出结果this.one是未定义变量。方法一:使用箭头函数的方式设置回调var ...

Spark 配置历史服务器_spark.history.ui.port-程序员宅基地

文章浏览阅读1k次。类似Hadoop,Spark也有自己的history server,这里我们就来配置下:修改 spark-defaults.conf.template 文件名为 spark-defaults.confmv spark-defaults.conf.template spark-defaults.conf修改 spark-default.conf 文件,配置日志存储路径spark.eventLog.enabled truespark.eventLog.dir _spark.history.ui.port

五大UNIX系统家族族谱_unix 族谱-程序员宅基地

文章浏览阅读2.1k次。UNIX操作系统不是某个特定操作系统实现,而是在遵循UNIX相关标准下的一个操作系统大家族,主要代表有SVR4、FreeBSD、Linux、Macc OS X、Solaris五大UNIX操作系统族谱家族名称维护者主要版本说明SVRUSLSVR3.2、SVR4 BSDCSRG4.2BSD(1983)、4._unix 族谱

计算机实验excel总结,EXCEL实验报告-程序员宅基地

文章浏览阅读1.7k次。《EXCEL实验报告》由会员分享,可在线阅读,更多相关《EXCEL实验报告(2页珍藏版)》请在人人文库网上搜索。1、实验报告班 级姓 名学 号日 期实验项目使用Excel进行会计各报表的核算及编制实验设备、用品机房计算机 Excel应用软件实验报告(实验目的与要求、实验基本过程、实验经验总结):实验目的与要求:通过学校可以使我熟练掌握使用excel中 一、实验目的:通过本次课程,使我们熟练掌握在计..._excel实验报告