前端编译过程
词法分析:将源代码的字符流转变为标记(Token)集合,单个字符是程序编写过程的最小元素, 而Token则是编译过程的最小元素 。
词法分析:将源代码的字符流转变为标记(Token)集合,单个字符是程序编写过程的最小元素, 而Token则是编译过程的最小元素 。
(关键字, 变量名, 字面量, 运算符 。。。)com.sun.toos.javac.parser.
Scanner
语法分析:根据Token序列构造抽象语法树的过程,
抽象语法树(Abstrace Syntax Tree,AST)是一种用来描述程序代码结构的树形表达式,
语法树的每一个节点都代表着程序代码中的一个语法结构(包, 类型,修饰符,运算符,接口,返回值甚至代码注解)
com.sun.tools.javac.tree.
JCTree
填充符号表:
符号表是由一组符号地址和符号信息构成的表格, 简单理解为K-V键值对, 符号表中所登记的信息在编译的不同阶段都要用到。
在语义分析中,符号表所登记的内容将用于语义检查(如检查一个名字的使用和原先的说明是否一致)和产生中间代码 。
在目标代码生成阶段,当对符号名进行地址分配时,
符号表是地址分配的依据。
com.sun.tools.javac.comp.
Enter
注解处理器:在编译期间对注解进行处理, 我们可以把它看做是
一组编译器的插件, 这些插件里面, 可以读取, 修改, 添加抽象语法树中的任意元素。
如果这些插件在处理注解期间对语法树尽心了修改, 编译器将回到解析及填充符号表过程重新处理
语义分析:对结构上正确的源程序进行详细阿文有关性质的审查, (语法树能表示一个结构正确的源程序的抽象, 但无法保证源程序是符合逻辑的)
1.标注检查:变量使用前是否已被声明,类型匹配,常量折叠。。。
2.数据及控制流分析:对程序上下文逻辑更进一步验证,变量使用前是否赋值,方法是否存在返回值, 异常是否被正常处理等。
解语法糖:自动装箱/拆箱 。。。
字节码生成:字节码生成是javac编译过程的最后一个阶段,把生成信息转化成字节码写道磁盘, 生成构造器,
字符串+操作替换为StringBuffer或StringBuilder
com.sun.tools.javac.jvm.
Gen
com.sun.tools.javac.
ClassWriter
后端编译过程
后端编译过程
即时编译器(Just In Time Compiler) : JIT编译器 : 把代码编译成渝本地平台相关的机器码 。
Java程序从
源码编译成
字节码和从字节码编译成
本地机器码的过程。
javac字节码编译器与
虚拟机内的JIT编译器的执行过程合并起来就是传统编译器所执行的编译过程。
注:资料来自: 深入理解Java虚拟机 (第二版) 作者: 周志明
注:资料来自: 深入理解Java虚拟机 (第二版) 作者: 周志明