JVM运行的基本流程_jvm有哪些部分组成运行流程-程序员宅基地

技术标签: JVM  java闲谈  

前言

|ू・ω・` )
因为在很多学习的途中,如果你想去理解一个东西的本质的话,肯定得去挖掘知识的底部。

在java中,JVM一直是java知识里面进阶阶段的重要部分。
如果希望在java领域研究的更深入,那JVM则是如论如何也避开不了的话题

所以今天我就给大家带了大概的JVM的一些介绍┗( ▔, ▔ )┛

JVM之运行流程

作为一名Java使用者,掌握JVM的体系结构也是必须的的,实际上说白点就是你运行main方法的时候是怎么走的。
可以看如下图:
在这里插入图片描述

简单的来理解,就是:

① Java源文件—->编译器(工具)—->字节码文件
② 字节码文件—->JVM(工具)—->机器码

嗯,如果还是不太懂得话可以演示一番:
比如写这行代码:

public class HelloWorld {
public static void main(String[] args) {
System.out.print(“Hello world”);
}
}

咱们可以去想它是怎么运行的呢?
在这里插入图片描述
大家看到那个加载配置了吗,其中的jvm.cfg文件,有兴趣的可以去找找
比如我的:

在这里插入图片描述
这个文件有什么用呢?
可以通过jvm.cfg文件找到对应的jvm.dll ,jvm.dll则是java虚拟机的主要实现。接下来会初始化JVM,并且获取JNI接口,什么是JNI接口,就是java本地接口。通过JNI接口(它还常用于java与操作系统、硬件交互),找到class文件后并装载进JVM,然后找到main方法,最后执行

额,可以普及下,JVM虚拟机有几种
在17年的时候有三种:

Sun公司的HotSpot;
BEA公司的JRockit;
IBM公司的J9 JVM;

嗯,有资料说:
由于Sun公司和BEA公司都被oracle收购,jdk1.8将采用Sun公司HotSpotBEA公司的JRockit两个JVM中精华形成jdk1.8的JVM。

哎,现在我们别管谁的,我们的任务是去理解原理不是吗 (’∇’)シ┳━┳

对了,我这是简单的说明而已,其实在 java源文件----->class文件的时候,大家不想知道怎么去转的吗?
额,有兴趣的可以去学习学习:

  1. Java源码编译机制
  2. 类加载机制
  3. 类执行机制

JVM之基本结构

ok,看了上面对JVM的流程,大概也有一点概念了吧,在将java源文件转为class文件后,接下来接手的就是JVM了,也就是最后转为机器码。
如图:
在这里插入图片描述
为了大家着想,不清楚的可以直接看下面:
在这里插入图片描述

嘛,看到这个东西实际上就是JVM的基本结构,
内存空间又称为:《Java 虚拟机运行时数据区域》

在运行过程中,各个模块分工合作,最终是由执行引擎完成class文件的执行

接下来给大家详细介绍下内存空间里的各个模板;


JVM之内存空间:方法区、java堆、java栈、本地方法栈

JVM内存空间包含:方法区、java堆、java栈、本地方法栈。

方法区

简单的说:
-----方法区是各个线程共享的区域,存放类信息、常量、静态变量。

细得说:
----- 静态变量+常量+类信息+运行时常量池存在方法区中,实例变量存在堆内存中。

就没啥了,重点在堆和栈


java堆(Heap 堆)

java堆也是线程共享的区域,
我们的类的实例就放在这个区域,可以想象你的一个系统会产生很多实例,因此java堆的空间也是最大的。如果java堆空间不足了,程序会抛出OutOfMemoryError异常。

也就是(Heap 堆

往细得走(有兴趣的可以看看):
堆这块区域是JVM中最大的,应用的对象和数据都是存在这个区域,这块区域也是线程共享的,也是 gc 主要的回收区,一个 JVM 实例只存在一个堆类存,堆内存的大小是可以调节的。
又分为三个部分:
在这里插入图片描述
① 新生区
新生区是类的诞生、成长、消亡的区域,一个类在这里产生,应用,最后被垃圾回收器收集,结束生命。新生区又分为两部分:伊甸区(Eden space)和幸存者区(Survivor pace),所有的类都是在伊甸区被new出来的。幸存区有两个:0区(Survivor 0 space)和1区(Survivor 1 space)。当伊甸园的空间用完时,程序又需要创建对象,JVM的垃圾回收器将对伊甸园进行垃圾回收(Minor GC),将伊甸园中的剩余对象移动到幸存0区。若幸存0区也满了,再对该区进行垃圾回收,然后移动到1区。那如果1去也满了呢?再移动到养老区。若养老区也满了,那么这个时候将产生Major GC(FullGCC),进行养老区的内存清理。若养老区执行Full GC 之后发现依然无法进行对象的保存,就会产生OOM异常“OutOfMemoryError”。

重点
如果出现java.lang.OutOfMemoryError: Java heap space异常,说明Java虚拟机的堆内存不够。原因有二:

  1. Java虚拟机的堆内存设置不够,可以通过参数-Xms、-Xmx来调整。
  2. 代码中创建了大量大对象,并且长时间不能被垃圾收集器收集(存在被引用)。

② 养老区
养老区用于保存从新生区筛选出来的 JAVA 对象,一般池对象都在这个区域活跃。

③ 永久区
永久存储区是一个常驻内存区域,用于存放JDK自身所携带的 Class,Interface 的元数据,也就是说它存储的是运行环境必须的类信息,被装载进此区域的数据是不会被垃圾回收器回收掉的,关闭 JVM 才会释放此区域所占用的内存。

重点
如果出现java.lang.OutOfMemoryError: PermGen space,说明是Java虚拟机对永久代Perm内存设置不够。原因有二:

  1. 程序启动需要加载大量的第三方jar包。例如:在一个Tomcat下部署了太多的应用。
  2. 大量动态反射生成的类不断被加载,最终导致Perm区被占满。

我还记得在之前做一个简单项目出现了溢出错误结果写了这个代码

<%@ page autoFlush="true"  buffer="1024kb" %>

java栈(Stack 栈)

java栈
是每个线程私有的区域,它的生命周期与线程相同,一个线程对应一个java栈,每执行一个方法就会往栈中压入一个元素,这个元素叫“栈帧”,而栈帧中包括了方法中的局部变量、用于存放中间状态值的操作栈。

如果java栈空间不足了,程序会抛出StackOverflowError异常,想一想什么情况下会容易产生这个错误,对,递归,递归如果深度很深,就会执行大量的方法,方法越多java栈的占用空间越大。

堆内存与栈内存需要说明:

基础数据类型直接在栈空间分配,方法的形式参数,直接在栈空间分配,当方法调用完成后从栈空间回收。引用数据类型,需要用new来创建,既在栈空间分配一个地址空间,又在堆空间分配对象的类变量 。方法的引用参数,在栈空间分配一个地址空间,并指向堆空间的对象区,当方法调用完成后从栈空间回收。局部变量new出来时,在栈空间和堆空间中分配空间,当局部变量生命周期结束后,栈空间立刻被回收,堆空间区域等待GC回收。方法调用时传入的literal参数,先在栈空间分配,在方法调用完成后从栈空间收回。字符串常量、static在DATA区域分配,this在堆空间分配。数组既在栈空间分配数组名称,又在堆空间分配数组实际的大小。

《上面的都是官方语言,可以看看可以加深理解,可以看图理解哦》

在这里插入图片描述

看图就轻松多了吧
这个也就是说你实列化的东西分别放在上面地方去了。


本地方法栈

就一句话
本地方法栈角色和java栈类似,只不过它是用来表示执行本地方法的,本地方法栈存放的方法调用本地方法接口,最终调用本地方法库,实现与操作系统、硬件交互的目的。

补充
PC寄存器
说到这里我们的类已经加载了,实例对象、方法、静态变量都去了自己改去的地方,那么问题来了,程序该怎么执行,哪个方法先执行,哪个方法后执行,这些指令执行的顺序就是PC寄存器在管,它的作用就是控制程序指令的执行顺序。


总结

写完这篇后,不知道大家有什么收获没,如果有些专业术语不太了解,也没什么事只要大家能明白JVM的大概流程和功能,就很有收获了。

也许有些东西不太正确,看出来的朋友可以提醒一下,我会改滴

Thanks♪(・ω・)ノ希望对大家有所帮助

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

智能推荐

linux系统bwa安装,BWA安装报错解决方案-程序员宅基地

文章浏览阅读1.1k次。在使用虚拟机安装BWA时,出现报错,报错信息见下文。经过核查,虚拟机为32位的系统,而BWA主要支持64位系统,由于相关配置太多,不想重装系统重新来过,解决方案如下:以bwa-0.7.4版本为例,修改Makefile文件前面几行:CC= gccCFLAGS= -g -Wall -O2 -msse -mmmx-msse2AR= arDFLAGS= -DHAVE_PTHREADLOBJS= ..._bwa安装 变量‘oldinversesa0relativerank’被设定但未被使用 [-wunused-but-set-

计算机网络知识点总结_1c低1111-程序员宅基地

文章浏览阅读5.8k次,点赞4次,收藏37次。计算机网络知识点总结(每日更新)_1c低1111

软件开发中 前台、中台、后台英文_企业架构 | 中台是什么?-程序员宅基地

文章浏览阅读1.7k次。中台这一概念,这两年在国内大热。2015年底,阿里集团宣布全面启动集团中台战略,构建符合DT时代的更具创新性、灵活性的“大中台、小前台”组织机制和业务机制。通过将产品技术力量和数据运营能力从前台剥离,成为能够独立为前台提供服务的中台,对前台业务形成强力支撑,从而使前台业务更加精简、敏捷,速适应瞬息万变的市场。中台一般具有三个功能属性:一是作为前台与后台的调节器,把可以复用的数据、经验、做法,集成为..._软件中台是什么意思

java与mysql8.0连接Jdbc驱动的配置参数_java mysql8连接参数-程序员宅基地

文章浏览阅读1k次。备忘记 2java与mysql8.0连接Jdbc驱动的配置参数driver:com.mysql.cj.jdbc.Driverurl:jdbc:mysql://localhost:3306/xxx?useUnicode=true&serverTimezone=GMT&characterEncoding=UTF-8&useSSL=false_java mysql8连接参数

C语言“…”占位符及可变参数函数-程序员宅基地

文章浏览阅读1.8k次,点赞2次,收藏4次。C语言函数的参数传递总是固定了个数,那么有没有传递任意个数参数的方法呢?在C++中,函数重载提供了多种参数传递的解决办法,但也不是任意参数个数。事实上,C语言是提供任意数量参数的解决方案的。printf(),scanf()等就是这样一类可支持任意参数个数变量的函数,以下是printf的用法示例。1printf("%d",x);..._scanf_s 占位符和其参数预计 1 可变参数

Simplygon软件之SimplygonUI 编辑器界面-程序员宅基地

文章浏览阅读2.8k次。Simplygon UISimplygonUI 默认布局Simplygon 安装完成后,可以双击快捷图标启动软件,软件启动后需要登入,登陆方式有两种1.Grid:在安装有 Simplygon Grid Server 功能的其他本地服务器上处理工作选择 Grid 选项卡输入 登陆凭证 和 服务器 IP 地址进行登陆,用户管理和凭证通过 Simplygon Grid管理实用程序进行管理 Si..._simplygon

随便推点

clickhouse(十二、踩坑之路)_attempt to read after eof: cannot parse int32 from-程序员宅基地

文章浏览阅读2.1w次,点赞11次,收藏36次。Q1DB::Exception: Cannot create table from metadata file /data/clickhouse/metadata/default/dwd_test.sql, error: DB::Exception: The local set of parts of table default.dwd_test doesn’t look like the set of parts in ZooKeeper: 65.88 million rows of 85.04 mi._attempt to read after eof: cannot parse int32 from string, because value is

python基础教程-数字与表达式——浮点数_python表达浮点数的两种方式-程序员宅基地

文章浏览阅读621次。1、python的加减乘数与计算机的加减乘除几乎差不多 + - * /2、如果参数除法中有一个为浮点数结果 亦为浮点数 >>> 1.0 / 2.0 0.5 >>> 1/2.0 0.53 、 双斜线 // 实现整除的操作符 >>> 1.0 // 2.0 0.0 >>> 1 // _python表达浮点数的两种方式

西瓜书《机器学习》课后答案——Chapter6_6.3_实验二、自主选择两个uci数据集,分别用高斯核训练svm分类器以及bp神经网络进行分-程序员宅基地

文章浏览阅读8.2k次,点赞5次,收藏45次。6.3 选择两个UCI数据集,分别用线性核和高斯核训练一个SVM,并与BP神经网络和C4.5决策树进行实验比较。 解答: (1) 准备libsvm的训练数据与测试数据从UCI网站上选择了Iris数据集,这个数据集总共分为3类,每类50个样本,每个实例有四个属性。数据保存在bezdekIris.txt文件中,举一个样本为例:5.1,3.5,1.4,0.2,Iris-setosa书中也没有介绍解决多_实验二、自主选择两个uci数据集,分别用高斯核训练svm分类器以及bp神经网络进行分

HBase-2.4.6安装教程 附常见错误解决_hbase2.4.6-程序员宅基地

文章浏览阅读741次。我这里采用了jdk1.8.0_301+hadoop-3.3.1+zookeeper-3.6.3+hbase-2.4.6的版本不同版本可能不能兼容,兼容性问题可以去官网查看http://hbase.apache.org/book.html#_preface我这里有三台虚拟机,hadoop102,hadoop103,hadoop1041、zookeeper正常部署首先保证三台机器的zookeeper正常启动[user@hadoop102 zookeeper-3.6.3]$ bin/zkServer.s_hbase2.4.6

技术合同填写说明_本合同履行完毕后,上述技术资料按以下方式处理-程序员宅基地

文章浏览阅读6.1k次,点赞4次,收藏7次。技术合同填写说明 所属类别:办事指南 发布时间:2009年6月12日 合同编号: 技术开发(委托)合同 项目名称:用简明、准确的文字表达合同的标的和名称 委托方(甲方):用《企业法人营业执照》规定的法定名称 (买方)_本合同履行完毕后,上述技术资料按以下方式处理

Exynos4412异步串口通信及实验_异步串行通信方式数据值怎么求-程序员宅基地

文章浏览阅读3.7k次,点赞2次,收藏12次。通信传输方式串行通信(二进制) 串行传送,数据是按顺序一位一位传送,一条数据线或差分线传输并行通信 数据各位同时传送,多条数据线比较:串行通常传输速度比较慢,成本低,适用于计算机间的远距离传输。并行传输速率高,成本也高,适用于近距离设备传输,当然了还有RS-485,RS-422,使用了串行差分通信总线,传输速率快,抗干扰性能好,同时传输距离远。同步传输与异步传输_异步串行通信方式数据值怎么求

推荐文章

热门文章

相关标签