JDK、JRE 和 JVM 的区别和联系

简介: JDK、JRE 和 JVM 的区别和联系

三者关系

就这三者的关系而言,jvm是jre的子集,jre是jdk的子集,具体关系如下图:

Java的执行流程

对于一个Java程序,其执行流程大致如下:

  1. 开发人员使用JDK编写和编译Java源代码,生成Java字节码文件(.class文件)。
  2. 在目标计算机上,通过命令行或集成开发环境(IDE)运行Java程序。此时,JVM会加载并执行Java字节码(.class文件)。
  3. JVM执行Java程序,按照程序的逻辑执行各个方法和语句,调用JRE中的类库。
  4. 在程序执行期间,JVM负责内存管理、垃圾回收,处理异常以及映射到本地系统。

下面是这三者的概念的具体解释

JDK(Java 开发工具包)

  1. Java 编译器(javac):用于将 Java 源代码文件(.java 文件)编译成 Java 字节码文件(.class 文件)的工具。这是将源代码转换为可执行程序的关键步骤。
  2. Java 虚拟机(JVM):JDK 包含 Java 虚拟机,它负责在计算机上执行 Java 字节码。JVM 是 Java 应用程序的运行时引擎,它负责加载字节码并将其转换为机器代码。
  3. Java 核心类库:JDK 包括了 Java 编程语言的核心类库,这些库包含了许多常用的类和方法,用于各种任务,如字符串处理、集合操作、文件操作、输入输出等。
  4. 开发工具:JDK 提供了各种开发工具,包括调试器(jdb)、文档生成工具(javadoc)、性能分析器、反编译器等,这些工具帮助开发人员编写、测试和优化 Java 代码。
  5. 头文件和开发库:JDK 包含了头文件和开发库,这些文件用于开发本机方法和与 Java 本机接口(JNI)相关的功能。这允许 Java 代码与本机库进行交互,从而扩展 Java 的功能。
  6. 示例代码和演示:JDK 包括一些示例代码和演示,这些示例帮助开发人员学习如何使用不同的 Java 类和库。
  7. API 文档:JDK 包括完整的 Java API 文档,可以在本地或在线访问。这些文档提供了有关 Java 类、方法和包的详细信息,以及示例代码和用法说明。
  8. 其他工具和实用程序:JDK 还包含其他实用工具和实用程序,如键库管理工具(keytool)用于管理数字证书和密钥库,以及部署工具用于将应用程序部署到服务器上。

JRE(Java 运行时环境)

  1. Java 虚拟机(JVM):JVM 是 JRE 的核心组件,它负责执行 Java 字节码并管理 Java 程序的运行时环境。
  2. 核心类库(Core Libraries):JRE 包括了一系列的核心类库,这些类库包含了 Java 编程语言的基本功能和工具。一些重要的核心库包括:
  • java.lang:提供了 Java 语言的基本类和异常处理机制。
  • java.util:包含各种实用工具类,例如集合框架(如 ArrayList、HashMap)和日期时间处理类。
  • java.io:用于输入和输出操作的类库,包括文件操作和流处理。
  • java.net:用于网络通信的类库,支持创建网络连接和数据传输。
  1. AWT 和 Swing(用户界面库):JRE 包括 Abstract Window Toolkit (AWT) 和 Swing,这些库用于创建图形用户界面(GUI)应用程序。它们提供了各种组件和工具,允许开发人员构建交互式的窗口应用程序。
  2. Java 核心包(Java API):JRE 还包括其他的 Java API,用于访问不同领域的功能和服务,如数据库访问(JDBC)、XML 处理(Java XML API)、安全性(Java Security API)等。
  3. Java 运行时支持:JRE 包括支持 Java 程序的运行时环境,包括内存管理、垃圾回收、线程管理等。这些组件保证了 Java 程序的稳定性和性能。
  4. 部分标准扩展(Optional Extensions):JRE 还可以包括一些可选的扩展,这些扩展提供了额外的功能,如 Java Naming and Directory Interface (JNDI)、Java Authentication and Authorization Service (JAAS) 等。这些扩展通常不是所有 JRE 实现的一部分,而是根据需要进行安装或配置。

JVM(Java 虚拟机)

  1. 类加载器(Class Loader)
  • 类加载器负责加载类文件并将其转换为 JVM 内部的数据结构。JVM 支持多个类加载器,包括启动类加载器、扩展类加载器和应用程序类加载器,它们按照不同的类路径加载类文件。
  1. 运行时数据区域(Runtime Data Areas)
  • JVM 包括多个运行时数据区域,用于存储程序执行期间所需的数据和信息。这些数据区域包括:
  • 方法区(Method Area):用于存储类的结构信息、静态变量、常量池等。
  • 堆(Heap):用于存储对象实例,包括由程序员创建的对象和Java虚拟机创建的对象(例如字符串池和类的实例)。
  • 虚拟机栈(Java Virtual Machine Stack):每个线程都有一个虚拟机栈,用于存储方法的局部变量和部分计算结果,以及用于方法调用和返回的操作。
  • 本地方法栈(Native Method Stack):类似于虚拟机栈,但用于本地方法(通过JNI接口调用的方法)的执行。
  • 程序计数器(Program Counter):用于指示当前线程正在执行的指令地址。
  1. 执行引擎(Execution Engine)
  • 执行引擎负责执行 Java 字节码。它包括解释器和即时编译器(JIT 编译器),可以将字节码转化为本地机器代码以提高执行速度。
  1. 本地接口(Native Interface)
  • JVM 提供了本地接口,允许 Java 程序与本地代码(如C/C++)进行交互。这通过 Java Native Interface(JNI)来实现。
  1. 本地方法库(Native Method Libraries)
  • JVM 包括一组本地方法库,这些库包含了 Java 标准库中的一些方法的本地实现,以及其他与底层操作系统和硬件相关的功能。
  1. 安全性和内存管理(Security and Memory Management)
  • JVM 负责内存管理,包括自动内存回收(垃圾回收)以释放不再使用的对象。它还实施了许多安全性功能,如类加载器安全性、访问控制和沙箱安全性。
  1. 多线程支持(Multithreading Support)
  • JVM 允许 Java 程序创建和管理多个线程,以便并发执行代码。
  1. 垃圾回收器(Garbage Collector)
  • 垃圾回收器是 JVM 的一部分,负责识别和回收不再被引用的对象,以释放内存空间。
目录
相关文章
|
2月前
|
存储 算法 Java
jvm性能优化(一)-基于JDK1.8
jvm性能优化(一)-基于JDK1.8
|
2月前
|
Java
安装JDK18没有JRE环境的解决办法
安装JDK18没有JRE环境的解决办法
321 3
|
3月前
|
Java
No compiler detected, make sure you are running on top of a JDK instead of a JRE
No compiler detected, make sure you are running on top of a JDK instead of a JRE
50 1
|
3月前
|
C# Windows 开发者
当WPF遇见OpenGL:一场关于如何在Windows Presentation Foundation中融入高性能跨平台图形处理技术的精彩碰撞——详解集成步骤与实战代码示例
【8月更文挑战第31天】本文详细介绍了如何在Windows Presentation Foundation (WPF) 中集成OpenGL,以实现高性能的跨平台图形处理。通过具体示例代码,展示了使用SharpGL库在WPF应用中创建并渲染OpenGL图形的过程,包括开发环境搭建、OpenGL渲染窗口创建及控件集成等关键步骤,帮助开发者更好地理解和应用OpenGL技术。
245 0
|
3月前
|
Java 编译器 开发工具
JDK vs JRE:面试大揭秘,一文让你彻底解锁Java开发和运行的秘密!
【8月更文挑战第24天】JDK(Java Development Kit)与JRE(Java Runtime Environment)是Java环境中两个核心概念。JDK作为开发工具包,不仅包含JRE,还提供编译器等开发工具,支持Java程序的开发与编译;而JRE仅包含运行Java程序所需的组件如JVM和核心类库。一个简单的"Hello, World!"示例展示了两者用途:需借助JDK编译程序,再利用JRE或JDK中的运行环境执行。因此,开发者应基于实际需求选择安装JDK或JRE。
55 0
|
3月前
|
缓存 Java 编译器
JRE、JDK、JVM 和 JIT 之间的区别详解
【8月更文挑战第22天】
126 0
|
3月前
|
Java
cxf 动态调用 WebService No compiler detected, make sure you are running on top of a JDK instead of a JRE
cxf 动态调用 WebService No compiler detected, make sure you are running on top of a JDK instead of a JRE
71 0
|
1月前
|
存储 安全 Java
jvm 锁的 膨胀过程?锁内存怎么变化的
【10月更文挑战第3天】在Java虚拟机(JVM)中,`synchronized`关键字用于实现同步,确保多个线程在访问共享资源时的一致性和线程安全。JVM对`synchronized`进行了优化,以适应不同的竞争场景,这种优化主要体现在锁的膨胀过程,即从偏向锁到轻量级锁,再到重量级锁的转变。下面我们将详细介绍这一过程以及锁在内存中的变化。
37 4
|
7天前
|
Arthas 监控 Java
JVM进阶调优系列(9)大厂面试官:内存溢出几种?能否现场演示一下?| 面试就那点事
本文介绍了JVM内存溢出(OOM)的四种类型:堆内存、栈内存、元数据区和直接内存溢出。每种类型通过示例代码演示了如何触发OOM,并分析了其原因。文章还提供了如何使用JVM命令工具(如jmap、jhat、GCeasy、Arthas等)分析和定位内存溢出问题的方法。最后,强调了合理设置JVM参数和及时回收内存的重要性。
|
5天前
|
Java Linux Windows
JVM内存
首先JVM内存限制于实际的最大物理内存,假设物理内存无限大的话,JVM内存的最大值跟操作系统有很大的关系。简单的说就32位处理器虽然可控内存空间有4GB,但是具体的操作系统会给一个限制,这个限制一般是2GB-3GB(一般来说Windows系统下为1.5G-2G,Linux系统下为2G-3G),而64bit以上的处理器就不会有限制。
8 1