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
愿你我在人生的路上能都变成最好的自己,能够成为一个独挡一面的人
© 每天都在变得更好的阿飞云
Java内存管理-初始JVM和JVM启动流程(二)的更多相关文章
- CC3200模块的内存地址划分和bootloader,启动流程(二)
1. 首先启动内部ROM固化的BOOT,然后这个ROM启动需要使用内存空间0X2000 0000 --- 0X2000 4000共16K的空间.一级BOOT的作用是串口升级和驱动库. 2. 然后是二级 ...
- Java内存管理-掌握虚拟机类加载器(五)
勿在流沙筑高台,出来混迟早要还的. 做一个积极的人 编码.改bug.提升自己 我有一个乐园,面向编程,春暖花开! 上一篇介绍虚拟机类加载机制,讲解了类加载机制中的三个阶段,分别是:加载.连接(验证.准 ...
- Java内存管理-掌握虚拟机类加载机制(四)
勿在流沙筑高台,出来混迟早要还的. 做一个积极的人 编码.改bug.提升自己 我有一个乐园,面向编程,春暖花开! 上一篇介绍了整个JVM运行时的区域,以及简单对比了JDK7和JDK8中JVM运行时区域 ...
- Java内存管理:Java内存区域 JVM运行时数据区
转自:https://blog.csdn.net/tjiyu/article/details/53915869 下面我们详细了解Java内存区域:先说明JVM规范定义的JVM运行时分配的数据区有哪些, ...
- Java内存管理-JVM内存模型以及JDK7和JDK8内存模型对比总结(三)
勿在流沙住高台,出来混迟早要还的. 做一个积极的人 编码.改bug.提升自己 我有一个乐园,面向编程,春暖花开! 上一篇分享了JVM及其启动流程,今天介绍一下JVM内部的一些区域,以及具体的区域在运行 ...
- 简单的例子 关于Java内存管理的讲解
我想做的是,逐行读取文件,然后用该行的电影名去获取电影信息.因为源文件较大,readlines()不能完全读取所有电影名,所以我们逐行读取. 就这段代码,我想要在位置二处使用base64,然后结果呢? ...
- java内存管理(堆、栈、方法区)
java内存管理 简介 首先我们要了解我们为什么要学习java虚拟机的内存管理,不是java的gc垃圾回收机制都帮我们释放了内存了吗?但是在写程序的过程中却也往往因为不懂内存管理而造成了一些不容易察觉 ...
- Java内存管理笔记
java内存管理机制 在java中,内存管理由JVM完全负责,java中的"垃圾回收器"负责自动回收无用对象占据的内存资源,这样可以大大减少程序猿在内存管理上花费的时间,可以更集中 ...
- Java 内存管理
java 内存管理机制 JAVA 内存管理总结 java 是如何管理内存的 Java 的内存管理就是对象的分配和释放问题.(两部分) 分配 :内存的分配是由程序完成的,程序员需要通过关键字 new 为 ...
随机推荐
- 2017-2018-2 20155303『网络对抗技术』Final:Web渗透获取WebShell权限
2017-2018-2 『网络对抗技术』Final:Web渗透获取WebShell权限 --------CONTENTS-------- 一.Webshell原理 1.什么是WebShell 2.We ...
- Docker容器数据卷
⒈Docker容器中数据如何持久化? ①通过commit命令使容器反向为镜像 ②以容器数据卷的方式将数据抽离 ⒉容器数据卷的作用? ①容器数据的持久化 ②容器间继承.共享数据 ⒊能干嘛? 卷就是目录或 ...
- 【转】Python中的字符串与字符编码
[转]Python中的字符串与字符编码 本节内容: 前言 相关概念 Python中的默认编码 Python2与Python3中对字符串的支持 字符编码转换 一.前言 Python中的字符编码是个老生常 ...
- ARMV8 datasheet学习笔记3:AArch64应用级体系结构
1.前言 本文主要从应用的角度介绍ARMV8的编程模型和存储模型 2. AArch64应用级编程模型 从应用的角度看到的ARM处理器元素: 可见的元素(寄存器/指令) 说明 可见的寄存器 R0-R30 ...
- 反向代理负载均衡之APACHE
反向代理负载均衡之APACHE 一.反向代理1.1 介绍反响代理 反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将 ...
- centos6环境创建局域网http方式的yum源
环境: yum服务器:centos 6.3 :192.168.8.20 yum源客户端:centos6.5 使用的主要rpm包来自centos6.5光盘 yum源服务器端配置: 1. 首先需要检查一下 ...
- centos6.5报错:checking filesystems failed问题处理
centos系统重启报错:checking filesystems failed checking filesystems /dev/mapper/vg_0-root: 搜了下可能是文件系统损坏 根据 ...
- vue系列之webstrom开发vue,无法热更新
用vue-cli构建了项目之后在webstorm开发,用npm run dev跑本地服务,经常修改之后在浏览器刷新没反应,偶尔才会有刷新,需要重新跑一遍npm run dev才会更新,这是怎么回事呢? ...
- 用strings命令查看kafka-log内容
kafka的log内容格式还不没怎么了解,想快速浏览消息内容的话,除了使用它自带的kafka-console-consumer.sh脚本,还可以直接去看log文件本身,不过内容里有部分二进制字符,通过 ...
- hdu5178 尺取
会爆int /* 给定数轴上一些点对,问有多少点对之间的距离差不超过k 点对排序后尺取法:枚举每个左边界,找到一个右边界使得 */ #include<bits/stdc++.h> #def ...