JVM及跨平台原理
首先我们先来大概了解什么是JVM?
如果中国人(Windows平台)需要和美国人(Linux平台)交流,那么我们向对方说中国的语言(Windows上的Java文件),需要被翻译官(JVM)翻译成英文(运行在Linux上),对方才能听懂,同理如果要翻译成别国(其他平台)语言,则需要不同的翻译官(JVM)。
JVM,也就是Java虚拟机,就作为Java 的万能翻译机。
下面进行解析
Java源代码的运行过程:Java源代码(Java文件)通过Java编译器编译,变成Java的字节码(.class文件,此时即可跨平台),Java字节码文件先通过类装载器字节码的验证,再进入JVM运行,再到操作系统,最后到达硬件层(见图1-1)。使得Java字节码文件可以运行在Windows、Linux、Solaris等不同平台。
我们可以把JVM理解成一个可运行 Java 字节码的虚拟计算机系统 ,它有一个解释器组件,可以实现 Java 字节码和计算机操作系统之间的通信。且对于不同的运行平台,有不同的JVM。
图1-1
GC
JVM 提供了一种系统线程跟踪存储空间的分配情况。并在 JVM 的空闲时,检查并释放那些可以被释放的存储空间。
需要GC的内存区域。JVM 中,程序计数器、虚拟机栈、本地方法栈都是随线程而生随线程而灭,栈帧随着方法的进入和退出做入栈和出栈操作,实现了自动的内存清理,因此,我们的内存垃圾回收主要集中于 java 堆和方法区中,在程序运行期间,这部分内存的分配和使用都是动态的。
垃圾回收器在 Java 程序运行过程中自动启用,程序员无法精确控制和干预。
Java跨平台原理及其两种核心机制:JVM和GC
最新推荐文章于 2023-05-17 08:33:58 发布