网易首页 > 网易号 > 正文 申请入驻

Java 编译期与运行期,别傻傻分不清楚

0
分享至

来源:小小木的博客

不知大家有没有思考过,当我们使用IDE写了一个Demo类,并执行main函数打印 hello world时都经历了哪些流程么?想通过这篇文章来分析分析Java的执行流程,或者换句话说想聊聊Java的编译期与运行期的流程。

  • 开门见山
  • 编译期间都做了什么
  • 运行期间都做了什么
1. 开门见山

public class MyApp { public static void main(String[] args) { System.out.println("hello world"); }}

假如我们写了一个MyApp.java,并要打印‘hello world’ 那它需要经过哪些步骤?

第一步compile

第二步load and execute

加载java 字节码并执行

可以通过jdk 里的java命令运行java字节码,我们只需 java MyApp.class 即可加载并执行该字节码,当运行java命令时,JRE将与您指定的类一起加载。然后,执行该类的主要方法。

上面只是大概讲了运行一个java程序的流程,下面再从编译期以及运行期的角度再剖析一下细节。

2. 编译期间都做了什么?

编译器(compiler)是一种计算机程序,它会将某种编程语言写成的源代码(原始语言)转换成另一种编程语言(目标语言)。

编译期都做了什么?从我们使用者角度看无非就是把源代码编译成了可被虚拟机执行的字节码,但是从平台(编译器)角度看,它所经历的流程还不少。毕竟总不能给你什么以.java为后缀的文件都进行编译吧,需要有各种校验解析步骤

2.1 解析与填充符号表

词法语法分析

词法分析

是指把源代码的字符流转为标记(Token)集合,标记(Token)是编译阶段的最小单元,字符则是编程阶段源码的最小单元。比如,int i = 0由4个标记构成分别是「int,i,=,0」编译器只认识这些标记,词法分析过程就是识别一个个标记的过程

语法分析

则是把生成的标记集合构成一个语法树,每个节点代表程序代码中的语法结构,如包,类型,修饰符,运算符等等。

填充符号表通过了上面的词义语义分析之后我们需要把数据存起来,以供后续流程使用,编译器会以key-value的形式存储数据,以符号地址为key符号信息为value,具体形式没做限制可以是树状符号表或者有序符号表等。在语义分析中,根据符号表所登记的内容 语义检查和产生中间代码,在目标代码生成阶段,当对符号表进行地址分配时,该符号表是检查的依据。

2.2 注解处理器

注解与普通的Java代码一样,是在运行期间发挥作用的。我们可以把它看做是一组编译器的插件,在这些插件里面,可以读取、修改、添加抽象语法树中的任意元素。如果这些插件在处理注解期间对语法树进行了修改,编译器将回到解析及填充符号表的过程重新处理,直到所有插入式注解处理器都没有再对语法树进行修改为止。换句话说当我们处理注解时如果修改了语法树的话会重新执行分析以及符号填充过程,把注解也填充进来,直到处理完所有注解。

2.3 语义分析

语法分析以及处理注解之后,编译器获得了程序代码的抽象语法树,语法树能表示一个结构正确的源程序的抽象,但无法保证源程序是符合逻辑的。说白了,语法树上的内容单个来说是合法的但是结合到上下文语义则未必是合法的。

比如定义了两个变量

int a = 1; boolean b = false;int c = a + b

以上 都能构成结构正确的语法树,但是根据语义分析之后编译是通不过,Java语言中是不合乎逻辑的。

2.4 解语法糖

Java 中最常用的语法糖主要有泛型、变长参数、条件编译、自动拆装箱、内部类等。虚拟机并不支持这些语法,它们在编译阶段就被还原回了简单的基础语法结构,这个过程成为解语法糖。

换句话说,不论你是否使用Java的语法糖,最终到jvm哪里的时候都是一样的,jvm不支持语法糖,所以需要编译阶段解语法糖,语法糖的初衷是用来提升开发效率,而不是代码性能。

2.5 字节码生成

字节码生成是Javac编译过程的最后一个阶段,在Javac源码里面由com.sun.tools.javac. jvm.Gen类来完成。字节码生成阶段前面各个步骤所生成的信息(语法树、符号表)转化成字节码写到磁盘中,主要工作就是把语法树和符号表加工成字节码文件。

3. 运行期间都做了什么?

java的运行期主要是处理编译器产生的字节码,包括加载与执行

3.1 加载器与验证器

java提供类加载器把虚拟机外部的字节码资源载入到虚拟机的运行时环境(主要是指虚拟机的方法区)并提供字节码验证器来保证载入的字节码是安全合法的,对程序没有危害的。

加载器 (Class Loader)

当字节码还没被类加载器加载之前它目前还处于虚拟机外部存储空间里,要想执行它需要通过类加载器来加载到虚拟机的运行时内存空间里。关于类加载器不太想过多扩展,有兴趣珂查阅相关书籍资料。

常见类加载器有:

  • Bootstrap ClassLoader(启动类加载器:加载位于\\lib 目录下的类文件,如rt.jar
  • Extension ClassLoader(扩展类加载器): 加载位于\\lib\\ext目录下的类文件
  • Application ClassLoader(应用程序类加载器):加载位于类路径(ClassPath)下的类文件

总之,加载器的任务就是把字节码资源载入到虚拟机运行时环境里

字节码验证 (Bytecode Verifier)

当类加载器将新加载的字节码呈现给虚拟机时,首先由验证器来检查验证这些字节码。验证程序检查指令是否无法执行明显有害的操作。除系统类之外的所有类都需要经过验证。也可以使用命令-noverify选项来停用验证。

字节码验证器主要验证如下几项:

  • 变量在使用前初始化
  • 不违反访问私有数据和方法的规则
  • 运行时堆栈不会溢出
  • 所有Java虚拟机指令的参数都是有效类型
  • 各种类型检查
参考 http://docs.oracle.com/javase/specs/jvms/se7/html/jvms-4.html#jvms-4.10。

总之,验证器的任务就是保证加载器载入的字节码资源的安全性,正确性

3.2 解释器与JIT编译器

解释器

解释器(interpreter),是一种计算机程序,能够把高级编程语言一行一行解释 运行。

划重点:一行一行运行,说白了就是效率低

解释器每次运行程序时都要一行一行先转成另一种语言再作运行,因此解释器的程序运行速度比较缓慢。它不会一次把整段代码翻译出来,而是每翻译一行程序叙述就立刻运行,然后再翻译下一行,再运行,如此不停地进行下去。

JIT编译器

即时编译(Just-in-time compilation)是一种提高程序运行效率的方法。通常,程序在执行前全部被翻译为机器码。

Java最初的版本没有JIT编译器,完全靠解释器来运行的,但是为了提升性能便引入了JIT编译器,

重点说明:当我们说编译的时候基本上指的是上面的从源码到字节码的编译过程,而不是指JIT编译器

JIT编译器工作阶段基本是java程序运行期的最后阶段了,它的工作是将加载的字节码转换为机器码。当使用JIT编译器时,硬件可以执行JIT编译器生成的机器码,而不是让JVM重复解释执行相同的字节码导致相对冗长的翻译过程。 这样可以带来执行速度的性能提升。

什么时候触发即时编译?

  • 被多次调用的方法
  • 被多次执行的循环体

上面两个条件又叫做热点代码,至于如何界定这个多次或者热点,Java提供了两种策略:

热点探测: 虚拟机定期检查线程的栈顶,如果某个方法经常出现在栈顶 则推断为热点代码

计数器: 统计方法的调用次数,维护一个计数器列表

基于计数器来推断热点代码是HotSpot虚拟机采用的策略

通常情况下,解释器和JIT编译器混合配合工作,而不是单独工作,这样可以做到互补提升整体性能。HotSpot 虚拟机的解释器JIT编译器架构如下图所示:

HotSpot虚拟机中内置了两个即时编译器,分别称为Client Compiler和Server Compiler,或者简称为C1编译器和C2编译器,默认采用解释器与其中一个编译器直接配合的方式工作,程序使用哪个编译器,取决于虚拟机运行的模式,用户也可以使用“-client”或“-server”参数去强制指定虚拟机运行在Client模式或Server模式。

4. 总结

java 程序是如何运行的?

首先需要把源代码(高级语言) 编译成虚拟机可执行的语言(字节码)其次,需要把字节码解释运行后者编译成操作系统级别的机器语言,用于执行函数调用(System call)

Java是如何做到平台独立的?

主要是因为字节码技术。我们可以把在Windows系统上编译生成的字节码文件放在Linux系统上去执行,反之亦可。虚拟机不在乎你是那个操作系统生成的字节码文件,他只在乎加载的这个.class字节码文件是否是正确的,安全的。

虽然Java语言是平台独立的,但是虚拟机不行。每种操作系统都要下载对应的虚拟机,这主要是由于它最终调用的函数库以及线程模型不同。

原文:https://www.cnblogs.com/wyc1994666/p/11366802.html

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
志愿军团长嫌敌人太弱,懒得去打,因此创下战争史上的一个奇迹

志愿军团长嫌敌人太弱,懒得去打,因此创下战争史上的一个奇迹

史之铭
2026-03-31 16:48:54
合砍24分,再中6记三分!火箭队双射手撑起2阵,航天城短板变优势

合砍24分,再中6记三分!火箭队双射手撑起2阵,航天城短板变优势

熊哥爱篮球
2026-03-31 11:53:36
就在今天!3月31日,传来焦泊乔新消息,杜锋这次真该反思了

就在今天!3月31日,传来焦泊乔新消息,杜锋这次真该反思了

砚底沉香
2026-03-31 17:13:06
TA:热刺与德泽尔比的战术适配度存疑,这笔签约是场“豪赌”

TA:热刺与德泽尔比的战术适配度存疑,这笔签约是场“豪赌”

懂球帝
2026-04-01 00:35:07
苦恋6年换来丈夫背叛,大度原谅他还连生2娃,胡紫薇爱的太卑微

苦恋6年换来丈夫背叛,大度原谅他还连生2娃,胡紫薇爱的太卑微

揽星河的笔记
2026-03-31 14:41:28
大学生女歌手和金主玩得野!绿大暗签AB替身陪大佬!

大学生女歌手和金主玩得野!绿大暗签AB替身陪大佬!

八卦疯叔
2026-03-30 16:11:55
被迫床上试戏?33号远征队"女主"曝自己重大失误

被迫床上试戏?33号远征队"女主"曝自己重大失误

游民星空
2026-03-29 22:04:14
创历史!雷霆首次连两季60胜 亚历山大47分连136场20+历史第一

创历史!雷霆首次连两季60胜 亚历山大47分连136场20+历史第一

醉卧浮生
2026-03-31 12:36:31
10-8逆转!小特会师墨菲手握2优势,吴宜泽创纪录,百岁对决打响

10-8逆转!小特会师墨菲手握2优势,吴宜泽创纪录,百岁对决打响

刘姚尧的文字城堡
2026-03-31 09:58:47
科学家潜水被巨鲸“纠缠”40分钟,真相却是在救她的命!

科学家潜水被巨鲸“纠缠”40分钟,真相却是在救她的命!

英国那些事儿
2026-03-30 23:24:02
410次开房记录流出:央企“女老虎”陶荔芳,背后还有多少同伙

410次开房记录流出:央企“女老虎”陶荔芳,背后还有多少同伙

深度报
2025-12-14 22:36:54
消息不妙,中国要警惕了,西方国家在重稀土领域已经取得突破!

消息不妙,中国要警惕了,西方国家在重稀土领域已经取得突破!

达文西看世界
2026-03-31 13:42:21
张凌赫那个高中暗恋的女孩被扒出来了!暗恋信也曝光了!

张凌赫那个高中暗恋的女孩被扒出来了!暗恋信也曝光了!

喜欢历史的阿繁
2026-03-30 18:05:49
官方:足球中国转播蒙太古杯小组赛首轮U16国少vs法国U16

官方:足球中国转播蒙太古杯小组赛首轮U16国少vs法国U16

懂球帝
2026-03-31 13:54:13
全球唯一双座隐身战机!歼-20S跨界作战有多震撼?专家解析

全球唯一双座隐身战机!歼-20S跨界作战有多震撼?专家解析

齐鲁壹点
2026-03-27 06:56:45
日媒:闯中国使馆暴徒最新供述再改口装无辜,日议员“必须道歉”

日媒:闯中国使馆暴徒最新供述再改口装无辜,日议员“必须道歉”

老糿尾声体育解说
2026-03-31 22:40:44
著名专家预言:试管婴儿寿命仅40年,那首例试管婴儿如今怎样了?

著名专家预言:试管婴儿寿命仅40年,那首例试管婴儿如今怎样了?

青梅侃史啊
2026-03-28 19:22:24
警惕!基层已变成“女儿国”

警惕!基层已变成“女儿国”

霹雳炮
2026-03-30 22:22:11
国民党大佬出手!马英九当场服软、向郑丽文交底,亲美派栽大跟头

国民党大佬出手!马英九当场服软、向郑丽文交底,亲美派栽大跟头

说历史的老牢
2026-03-30 13:37:41
王思聪舅舅林友涉连杀两任妻子+雇凶杀害肢解邻居,为啥还能逍遥法外21年?

王思聪舅舅林友涉连杀两任妻子+雇凶杀害肢解邻居,为啥还能逍遥法外21年?

不二表姐
2026-03-30 23:30:07
2026-04-01 01:12:49
Java架构技术
Java架构技术
专注于Java领域优质技术
502文章数 14662关注度
往期回顾 全部

科技要闻

华为2025年销售收入8809亿,净利润680亿元

头条要闻

男子玩具店买枪被羁押279天获国赔16万:打官司花40万

头条要闻

男子玩具店买枪被羁押279天获国赔16万:打官司花40万

体育要闻

县城修车工,用20年成为世界冠军

娱乐要闻

《月鳞绮纪》空降 鞠婧祎却被举报偷税

财经要闻

油价暴涨 我们的生活成本会飙升多少?

汽车要闻

腾势Z9GT到底GT在哪?

态度原创

手机
亲子
房产
数码
教育

手机要闻

OPPO新机突然官宣:4月21日带来全家桶!友商:或同一天!

亲子要闻

春天养好肝,和我一起种地来呗

房产要闻

重磅!海南城市更新拟出新政!

数码要闻

联想推出YOGA AI Mini迷你主机,5499元

教育要闻

微专题:高考地理中的地理实验

无障碍浏览 进入关怀版