Javac 编译原理
写在前面 JDK & JRE
JRE(Java Runtime Enviroment)是Java的运行环境。面向Java程序的使用者,而不是开发者。如果你仅下载并安装了JRE,那么你的系统只能运行Java程序。JRE是运行Java程序所必须环境的集合,包含JVM标准实现及 Java核心类库。它包括Java虚拟机、Java平台核心类和支持文件。它不包含开发工具(编译器、调试器等)。
JDK(Java Development Kit)又称J2SDK(Java2 Software Development Kit),是Java开发工具包,它提供了Java的开发环境(提供了编译器javac等工具,用于将java文件编译为class文件)和运行环境(提 供了JVM和Runtime辅助包,用于解析class文件使其得到运行)。如果你下载并安装了JDK,那么你不仅可以开发Java程序,也同时拥有了运行Java程序的平台。JDK是整个Java的核心,包括了Java运行环境(JRE),一堆Java工具tools.jar和Java标准类库 (rt.jar)。
JDK also could be called as SDK(Software Development Kit) for Java.
1.Javac是什么?
Javac是一种编译器,能将一种语言规范转化为另外一种语言规范。通常编译器都是将便于人理解的语言规范转化成机器容易理解的语言规范。
Javac的任务就是将java源码编译成java字节码,也就是JVM能够识别的二进制码。表面上来看就是将.java文件转化为.class文件,实际上是将java的源代码转化成一连串有格式的二进制数字,只有JVM能够正确识别它们到底表达了什么意思。
2.Javac的工作流程及类比
2.1 寻找语法关键词 比如if else for while 等,这个过程称为词法分析 (词法分析的结果是从源代码中找出一些规范化的Token流)
类比:人类语言中分辨 词语 标点符号 动词 名词
2.2 检查这些关键词组合在一起是否符合Java语言规范,这个过程称为语法分析 (语法分析的结果是一个符合Java规范的抽象语法树)
类比: 人类语言中是不是有主谓宾 主谓宾组合的是否正确 语法是否正确
2.3 将难懂的、复杂的语法转化为更加简单的语法,这个过程称为语义分析 (比如说将foreach转成for,结果是生成了一个注解过后的抽象语法树,这棵树更加接近目标语言的语法规则)
类比:人类语言中将难懂的文言文翻译为白话文
2.4 通过字节码生成器生成字节码,将经过注解的抽象语法树生成字节码,也就是将一个数据结构转化为另一个数据结构
类比:将中文词语翻译为英文单词后,按照英文语法组装成英文语句
综上所述,Javac主要有四个模块,分别是词法分析器、语法分析器、语义分析器和代码生成器。
3.词法分析器
package compile;
public class Cifa {
int a;
int c = a+1;
}
词法分析器的分析结果就是将这个类中的所有关键词匹配到token类的所有项中的任何一项。上述代码的匹配结果如下图

4.语法分析器
词法分析器的作用是将Java源文件的字符流转变成对应的Token流,而语法分析器是将Token流组建成更加结构化的语法树,也就是将一个个单词组装成一句话。
public class Yufa{
int a;
private int c =a +1;
public int getC(){
return c;
}
public void setC(int c){
this.c = c;
}
}
这段代码对应的语法树

5.语义分析器
经过语法分析器生成的语法树过于粗糙,此时需要在这颗语法树的基础上再做一些处理,比如给类添加构造函数、检查变量在使用前是否初始化、将一些常量进行合并处理,检查操作变量类型是否匹配,检查所有的操作语句是否可达,检查checked exception异常是否已经捕获或抛出,接触Java语法糖(泛型,装拆包),去除一些永不为真的条件判断,内部类会被分离出去但是持有一个外部类的引用
6.代码生成器
将Java方法中的代码块转化成符合JVM语法的命令形式,JVM的操作都是基于栈的,所有的操作都必须经过出栈和进栈来完成。
按照JVM的文件组织格式将字节码输出到以class为扩展名的文件中
Javac 编译原理的更多相关文章
- 第二章 Javac编译原理
注:本文主要记录自<深入分析java web技术内幕>"第四章 javac编译原理" 1.javac作用 将*.java源代码文件转化为*.class文件 2.编译流程 ...
- Knowledge Point 20180303 对比编译器、解释器与Javac编译原理
编译器与Javac编译原理 在前文我们知道了Java是一种编译语言和解释语言,它的源代码经过编译器Javac编译为能够被JVM识别的二进制语言,然后JVM将其解释为能够被平台识别的机器语言.那么什么是 ...
- javac编译原理(一)
我们都知道,计算机只能识别二进制语言,是不能直接识别java c c++等高级语言的.将高级语言转化成计算机可以是别的二进制语言,这个过程就叫编译. 有次面试,面试官问了一道“java的编译原理是什么 ...
- Javac编译原理 《深入分析java web 技术内幕》第四章
javac编译的四个主要的流程: 词法分析器:将源码转换为Token流 将源代码划分成一个个Token(找出java语言中的关键字) 语法分析器:将Token流转化为语法树 将上述的一个个Token组 ...
- 第四章 Javac编译原理
4.1 Javac是什么 是一种编译器,将JAVA源代码(.java文件)语言先转化成JVM能够识别的一种语言(.class文件),然后由JVM将JVM语言再转化成当前机器可以识别的机器语言. 4.2 ...
- 第四章 Javac编译原理(待续)
Javac是什么 Javac编译器的基本结构 Javac工作原理分析 设计模式解析之访问者模式
- javac编译原理
javac编译器的作用就是将符合java语言规范的源代码转化成符合java虚拟机规范的java字节码 经历:词法分析器->语法分析器->语义分析器->编译字节码 四个过程生成字节码文 ...
- javac 编译与 JIT 编译
编译过程 不论是物理机还是虚拟机,大部分的程序代码从开始编译到最终转化成物理机的目标代码或虚拟机能执行的指令集之前,都会按照如下图所示的各个步骤进行: 其中绿色的模块可以选择性实现.很容易看出,上图中 ...
- Javac编译和JIT编译
编译过程 不论是物理机还是虚拟机,大部分的程序代码从开始编译到最终转化成物理机的目标代码或虚拟机能执行的指令集之前,都会按照如下图所示的各个步骤进行: 其中绿色的模块可以选择性实现.很容易看出,上图中 ...
随机推荐
- SpringMVC获取页面数据乱码的解决get/post
一.post请求方式的乱码 在web.xml中加入: <filter> <filter-name>CharacterEncodingFilter</filter-name ...
- string,char*,int 之间的转化
c++中经常遇到string,char*,int之间的相互转化,今天就来整理一下. 以下是转载并修改的内容: 以下是常用的几种类型互相之间的转换 string 转 int先转换为char*,再使用at ...
- WPF蒙板弹窗
由于界面设计需要,要给弹窗添加蒙板效果,在百度和google搜索了半天,竟然没有一个满意的方案,最后只能自己想办法实现了一个,原理还是比较简单的,现在分享给大家. 先看一下效果.. 原理其实 ...
- Java面试准备之集合框架
集合框架 Collection:List列表,Set集 Map:Hashtable,HashMap,TreeMap Collection 是单列集合 List 元素是有序的(元素存取是有序).可重复 ...
- 粗略使用.NetCore2.0自带授权登陆Authorize
上篇有朋友提及到如果nginx做集群后应该还会有下一篇文章主讲session控制,一般来说就是登陆:本篇分享的内容不是关于分布式session内容,而是netcore自带的授权Authorize,Au ...
- Java基础---网络编程
第一讲 概述 1.网络模型:OSI参考模型和TCP/IP参考模型 图示: 一般来说开发处于传输层和网际层,应用层为:FTP和HTTP协议等,传输层为:UDP和TCP等,网际层为:IP. 通常用 ...
- Android艺术探索第四 view的自定义
一.初见View View的层级关系(Veiw到底分成几层,自定义view是从那一层开始绘制的) R:Veiw树的结构如下 ,自定义View是从DecorView开始的;DecorView是View树 ...
- python条件判断与循环
条件判断 1.python缩进规则: 如果if语句判断是True,就把缩进的语句执行了,否则,什么也不做,比如: age=20 if age >= 18: print('your age is' ...
- vue 父子组件传参
父向子组件传参 例子:App.vue为父,引入componetA组件之后,则可以在template中使用标签(注意驼峰写法要改成componet-a写法,因为html对大小写不敏感,component ...
- poj 3621 二分+spfa
题意:给出一个有向图,问求一个回路,使得回路上的点权之和/边权之和最大. 这题主要是分析出如何确定ans值.我们将(a1*x1+a2*x2+..+an*xn)/(b1*x1+b2*x2+..+bn*x ...