Java内存管理-初始JVM和JVM启动流程(二)

勿在流沙住高台,出来混迟早要还的。

做一个积极的人

编码、改bug、提升自己

我有一个乐园,面向编程,春暖花开!

上一篇分享了什么是程序,以及Java程序运行的三个阶段。也顺便提到了Java中比较重要的一个东西就是JVM(JAVA 虚拟机),那么今天在先了解一下JVM和JVM的启动流程。

知识地图:

1、什么是虚拟机

虚拟机(Virtual Machine)指通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机系统。【百度百科】

虚拟机通过仿真引擎(称为管理程序)处理虚拟硬件,包括CPU、内存、硬盘驱动器、网络接口和其他设备。虚拟机管理程序提供的虚拟硬件设备映射到物理机器上的实际硬件,表现为虚拟机的虚拟硬盘存储在硬盘驱动器上的文件中。

有哪些种类的虚拟机呢?

  • 系统虚拟机,例如:VMware、Visual box
  • 程序虚拟机,例如:Java虚拟机(JVM)
  • 操作系统层虚拟化,例如:Docker

上面这三种虚拟机类型,作为当代的程序员都一定听过或者用过吧,如果没有的话,那就跟上我的步伐,先学学JVM喽。

在说明一点:每一种类型的虚拟机都有不同和它们应对的使用场景:

  • VMVare或者Visual box 都是使用软件模拟物理CPU的指令集
  • JVM使用软件模拟Java 字节码的指令集

2、初始JVM

2.1 JAVA 和 JVM的历史

想要了解JVM那就一定要说一下Java的发展了,但是这里不对Java的发展做介绍,简单说明一下Java中的JDK和JRE(基础的东西也比较重要,因为面试可能回被闻到)!

JDK和JRE的区别 :JDK = JRE + Develop环境

JDK(Java Development Kit)是面向开发人员使用的SDK,它提供了Java的开发环境和运行环境。

JRE是Java Runtime Enviroment是指Java的运行环境,是面向Java程序的使用者,而不是开发者。

注意:一般在生产环境上只需要安装JRE就可以了!

引用网上的一张图片说明:

从Java发布也就是JDk1.0开始的Classic VM,到逐渐发展在JDK1.3的时候出现Hotspot(作为默认虚拟机发布),到JDK1.4 Classic VM退役,到目前Hotspot 依旧在继续发光发热。如下JDK1.8:

-- java -version
java version "1.8.0_121"
Java(TM) SE Runtime Environment (build 1.8.0_121-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.121-b13, mixed mode)


备注:

1、使用最为广泛的JVM为HotSpot 2、HotSpot为Longview Technologies开发,被SUN收购 3、2006年Java开源,并建立OpenJDK,HotSpot成为Sun JDK和OpenJDK中所带的虚拟机 4、2008年Oracle收购BEA,得到JRpckit VM 5、2010年Oracle 收购Sun,得到Hotspot 6、Oracle宣布在JDK8时整合JRockit和Hotspt,优势互补,在Hotspot基础上,一直JRockit优秀特性。

2.2 JVM规范简介

在JVM中定义了很多的规范,下面做个简单的介绍:

JAVA 语言规范

  • 语法
  • 变量
  • 类型
  • 文法

JVM 规范

  • Class文件类型
  • 运行时数据
  • 帧栈
  • 虚拟机的启动
  • 虚拟机的指令集

通过一系列的具体规范,符合规范的程序才能在JVM中进行运行,也就是无规矩不成方圆!

JVM是一个规范,一个文档,任何人或者组织都可以通过这个规范自己实现具体的JVM。

HotSpot 只是JVM规范的一个实现了(其他的JVM实现如:IBM J9 VM、JRockit等)。

这个可以类比JPA ,JPA也是一个规范了,目前JPA主要实现由hibernate和openJPA等。

3、JVM启动流程

平时我们在IDE中编写代码后,直接运行,根本感受JVM的存在。但是它的确真实存在,并且还有一套自己的运行流程。

其实初学JAVA的伙伴可能体会比较深,因为我们在文本中编写好代码后,要执行 javac 编译,然后在执行java进行运行。

那么整个JVM的启动流程是什么样子的呢?请看下图:

上面这张图和下面这一张图参考一起看:

其中的jvm.cfg 、jvm.dll 等在安装的jdk环境中都可以找到:

说明: 启动成功后,当该程序关闭退出,这个虚拟机实例也就随之消亡!如我们允许的main方面在IDE中控制台上面有个红色的点,那个点关闭变灰后也就意味着虚拟机实例的消亡。

总结

本篇简单介绍了JVM的一些基础的知识,后续慢慢深入学习,一起探索JVM世界!



谢谢你的阅读,如果您觉得这篇博文对你有帮助,请点赞或者喜欢,让更多的人看到!祝你每天开心愉快!



不管做什么,只要坚持下去就会看到不一样!在路上,不卑不亢!

博客首页 : http://blog.csdn.net/u010648555

愿你我在人生的路上能都变成最好的自己,能够成为一个独挡一面的人

© 每天都在变得更好的阿飞云

原文地址:https://www.cnblogs.com/aflyun/p/10569047.html

时间: 2024-08-01 06:15:35

Java内存管理-初始JVM和JVM启动流程(二)的相关文章

Java内存管理-掌握虚拟机类加载器(五)

勿在流沙筑高台,出来混迟早要还的. 做一个积极的人 编码.改bug.提升自己 我有一个乐园,面向编程,春暖花开! 上一篇介绍虚拟机类加载机制,讲解了类加载机制中的三个阶段,分别是:加载.连接(验证.准备.解析).初始化 ,知道了类加载的机制.下面我们就要知道类到底是通过什么方式加载到内存中的,也就是本文要介绍的类加载器,类加载器就是加载类的信息到内存中. 本文地图 : 一.什么是类加载器(ClassLoader) 虚拟机设计团队把类加载阶段中的”通过一个类的全限定名来获取描述此类的二进制字节流“

简单的例子 关于Java内存管理的讲解

我想做的是,逐行读取文件,然后用该行的电影名去获取电影信息.因为源文件较大,readlines()不能完全读取所有电影名,所以我们逐行读取. 就这段代码,我想要在位置二处使用base64,然后结果呢? 两处位置都打印了,位置一得到base64,ok,没问题.当我在位置二想使用base64时,问题来了?onload队列的问题,位置二总是无法正确的获取到想要的base64,这个时候就可以考虑异步问题了. 在还没有接触到angular的时候,还真的不知道它到底有什么作用,直到我开始学习它,并且运用到它

Java内存管理第二篇 - 内存的分配

Java内存管理无非就是对内存进行分配和释放.对于分配来说,基本类型和对象的引用存储到栈中,常量存储到常量池中,对象存储到堆上,这是一般的分配.而对于回收来说要复杂的多,如果回收不好,还可能造成分配出去的内存得不到回收而造成内存泄漏. 这一篇将简单介绍一下Java内存的分配,下一篇将介绍内存的回收及内存泄漏等知识. 1.JVM内存模型 1.程序计数器(Program Counter Register): 程序计数器是一个比较小的内存区域,用于指示当前线程所执行的字节码执行到了第几行,可以理解为是

java内存管理机制

JAVA 内存管理总结 1. java是如何管理内存的 Java的内存管理就是对象的分配和释放问题.(两部分) 分配 :内存的分配是由程序完成的,程序员需要通过关键字new 为每个对象申请内存空间 (基本类型除外),所有的对象都在堆 (Heap)中分配空间.释放 :对象的释放是由垃圾回收机制决定和执行的,这样做确实简化了程序员的工作.但同时,它也加重了JVM的工作.因为,GC为了能够正确释放对象,GC必须监控每一个对象的运行状态,包括对象的申请.引用.被引用.赋值等,GC都需要进行监控. 2. 

JAVA内存管理再解

首先我们要明白一点,我们所使用的变量就是一块一块的内存空间!! 一.内存管理原理:   在java中,有java程序.虚拟机.操作系统三个层次,其中java程序与虚拟机交互,而虚拟机与操作系统间交互!这就保证了java程序的平台无关性!下面我们从程序运行前,程序运行中.程序运行内存溢出三个阶段来说一下内存管理原理! 1.程序运行前:JVM向操作系统请求一定的内存空间,称为初始内存空间!程序执行过程中所需的内存都是由java虚拟机从这片内存空间中划分的. 2.程序运行中:java程序一直向java

揭开Java内存管理的面纱

前言 相对于C.C++这些高性能语言,Java有着让此类程序员羡慕的功能:内存自动管理.似乎这样,Java程序员不用再关心内存,也不用去了解相关知识.但结果真的是这样吗?特别对于我们这种Android程序员来说,对内存可是吃得死死的,一旦出现较为复杂的内存泄露和溢出方面的问题,简直就是噩梦.因此,对Java内存管理有个大体的了解似乎已经成为一个合格的Android程序员必备的技能,就算是新进的Kotlin同样是基于JVM的.不如趁此机会,大家一起来揭开它的面纱. 对象 Java是一门面向对象的编

java内存管理

一.jvm内存结构 程序计数器(Program Counter Register).JVM虚拟机栈(JVM Stacks).本地方法栈(Native Method Stacks).堆(Heap).方法区(Method Area) (1)PCR 跟随线程生命周期,记录当前执行到的.class字节码行数,用于多线程操作 (2)JVM Stacks 跟随线程生命周期,在方法执行中存储数据 (3)Native Method Stacks 处理native方法,如object中的hashCodes()等

【Java】Java内存管理

Java内存管理是面试中经常会问到的问题.Java的内存管理其实是指对象 的分配和释放问题.曾经看过这样一句话:"C++程序员觉得内存管理太重要了,所以一定要自己进行管理,而Java程序员觉得内存管理太重要了,一定不能自己管理".我觉得这句话说得太精辟了. C++程序员需要显式分配内存,释放内存,而这样常常会引起"内存泄露".而Java程序员不需要显式分配和释放内存,Java在创建对象的时候会自动分配内存,在对象不再使用的时候释放内存.Java的对象是通过new关键

Java内存管理的进一步理解-模拟过程图解

Java内存管理的进一步理解-模拟过程图解--转载 java的内存管理分为: 1.堆内存:2.栈内存:3.方法区:4.本地方法区 /* 1:方法区      方法区存放装载的类数据信息包括:      (1):基本信息:      1)每个类的全限定名       2)每个类的直接超类的全限定名(可约束类型转换)      3)该类是类还是接口      4)该类型的访问修饰符      5)直接超接口的全限定名的有序列表      (2):每个已装载类的详细信息:      1)运行时常量池: