什么是JVM
- 面试
- 理解底层实现原理
- 中高程序员的必备技能
一. JVM概述
定义:
Java Virtual Machine
-java程序的运行环境(java二进制字节码的运行环境)
-
Java虚拟机(英语:Java Virtual Machine,缩写为JVM),一种能够执行Java bytecode的虚拟机,以堆栈结构机器来进行实做。最早由Sun微系统所研发并实现第一个实现版本,是Java平台的一部分,能够执行以Java语言写作的软件程序。
-
Java虚拟机有自己完善的硬体架构,如处理器、堆栈、寄存器等,还具有相应的指令系统。JVM屏蔽了与具体操作系统平台相关的信息,使得Java程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行。通过对中央处理器(CPU)所执行的软件实现,实现能执行编译过的Java程序码(Applet与应用程序)。
-
作为一种编程语言的虚拟机,实际上不只是专用于Java语言,只要生成的编译文件符合JVM对加载编译文件格式要求,任何语言都可以由JVM编译运行。此外,除了甲骨文,也有其他开源或闭源的实现。
好处:
一次编写,到出运行
具有自动内存管理,垃圾回收功能
具有数组下标越界检查
使用虚方法调用的机制实现了多态
比较:
轮范围:JVM<JRE<JDK
JVM 是可运行 Java 代码的假想计算机 ,包括一套字节码指令集、一组寄存器、一个栈、一个垃圾回收,堆 和 一个存储方法域。
JVM 是运行在操作系统之上的,它与硬件没有直接的交互。
二. 常见的JVM
HotSpot
最著名的就是 oralce 公司的 HotSpot ,现在学习和使用的也都是这个jvm。 JVM 的全称是 Java Virtual Machine (java虚拟机),虚拟机是一种抽象化的计算机,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的
三. 学习路线
(一). JVM内存区域
JVM 内存区域:
线程私有区域 | 线程共享区域 |
---|---|
程序计数器、虚拟机栈、本地方法区 | JAVA 堆、方法区,直接内存 |
特别注意:
线程私有数据区域生命周期与线程相同, 依赖用户线程的启动/结束 而 创建/销毁(在 Hotspot VM 内
每个线程都与操作系统的本地线程直接映射, 因此这部分内存区域的存/否跟随本地线程的生/死对应)。线程共享区域随虚拟机的启动/关闭而创建/销毁
- 直接内存并不是 JVM 运行时数据区的一部分, 但也会被频繁的使用: 在 JDK 1.4 引入的 NIO 提
供了基于 Channel 与 Buffer 的 IO 方式, 它可以使用 Native 函数库直接分配堆外内存, 然后使用
DirectByteBuffer 对象作为这块内存的引用进行操作(详见: Java I/O 扩展), 这样就避免了在 Java
堆和 Native 堆中来回复制数据, 因此在一些场景中可以显著提高性能
- 运行环境
- 运行过程
我们都知道 Java 源文件,通过编译器,能够生产相应的Class 文件,也就是字节码文件,而字节码文件又通过 Java 虚拟机中的解释器
,编译成特定机器上的机器码
① Java 源文件—->编译器—->字节码文件
② 字节码文件—->JVM—->机器码
每一种平台的解释器是不同的,但是实现的虚拟机是相同的,这也就是 Java 为什么能够跨平台的原因了 ,当一个程序从开始运行,这时虚拟机就开始实例化了,
多个程序启动就会存在多个虚拟机实例
。程序退出或者关闭,则虚拟机实例消亡,多个虚拟机实例之间数据不能共享