JVM 简介

JVM 组成

JVM包含两个子系统和和两个组件,连个子系统为类装载(Class Loader)和执行引擎(Execution engine);两个组件为运行时数据区(Runtime data area),本地接口(Native Interface)。
类装载(Class Loader):根据给定的全限定名类名(如:java.lang.Object)来装载class 文件到 运行时数据区(Runtime data area )中的方法区(method area)
执行引擎(Execution engine):执行classes 中的指令。
本地接口(Native Interface) :与native libraries 交互,是其他编程语言交互的接口。
运行时数区域(Runtime data arae):这就是我们常说的JVM 内存

在这里插入图片描述

JVM 作用

首先通过编译器把java代码转换成字节码,类加载(Classloader)器再把字节码加载到内存中,将其放在运行时数据区(Runtime data area)的方法区(method area)内,而字节码文件只是JVM的一套指令集规范,并不能直接交给底层操作系统去执行,因此需要特定的命令解析器执行引擎(Execution Engine),将字节码翻译成底层系统指令,再交由cpu 去执行,而这个过程中需要调用其他语言的本地库接口(Native Interface) 来实现整个过程

java 程序运行机制的详细说明

1.首先利用IDE集成开发工具编写java源代码,源文件的后缀为:【.java】
2.再利用编译器(javac命令)将源代码编译成字节码文件,字节码文件的后缀为:【.class】
3.运行字节码的工作是由解释器(java命令来执行)
在这里插入图片描述

从上图可以看到。java文件通过编译器变成了class文件,接下来类加载器又将这些class文件加载到JVM中
总结:类的加载指的是将类的class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在堆中创建一个java.lang.Class对象来封装类在方法区的数据结构。

JVM运行时数据区

java 虚拟机在执行java程序的过程中会把它管理的内存区域划分成若干个不同的数据区域,这些区域都有各自的用途,以及创建和销毁的时间,有些区域随着虚拟机进程单位启动而存在,有些区域则是依赖线程的启动和结束而建立和销毁。java 虚拟机所管理的内存被划分为如下几个区域
在这里插入图片描述
不同虚拟机的运行时数据区可能会略微有所不同,但都会遵从java 虚拟机规范,java虚拟机规范规定的区域分为以下五部分:
程序计数器(Program Counter Register):当前线程所执行的字节码的行号指示器,字节码解析器的工作是通过改变这个计数器的值来选取下一条需要执行的字节码指令,分支、循环、跳转,异常处理、线程恢复等基础功能都需要依赖这个计数器来完成。
java 虚拟机栈(Java Virtual Machine Stacks):用于存储局部变量表,操作数栈,动态链接,方法的出口等信息。
本地方法栈(Native Method Stack):与虚拟机栈的作用是一样的,只不过虚拟机栈是服务java方法的,而本地方法栈是为虚拟机调用native方法服务的。
java推(java Heap):java 虚拟机中内存中内存最大的一块,是被所有线程共享的,几乎所有的对象实例都在这里分配内存,
方法区(Method area):用于存储已经被虚拟机加载的类信息,常量,静态变量,即时编译后的代码等数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值