Javac编译原理
@date:2018-5-16
@author:LF
大体过程
词法解析–》语法解析–》语义分析
具体过程理解
- 词法解析
源码文件会生成愈多的源码集合,感觉应该以空格分隔形成多个字符结合,每个集合原则上对应关键字,例如:
int a = 0; =>{int}{a}{=}{0}
然后每个字符集合生成一个name对象,按照一定顺序匹配TOKEN序列。
那么TOKEN序列是什么?
TOKEN序列就是JAVA关键字的集合,将关键字按照规定的语法顺序匹配TOKEN。
- 语法解析
按照一定规则匹配到TOKEN后,TOKEN与Name对应关系通过Name.table.keywords.key[]对应,然后建立语法树,语法树的基类是JCTree,所有语法树均派生于它。
如:JCCatch(对应catch语法),JCImport(对应Import语法)
相当于每一种语法都有一种语法树的数据结构对应,匹配完TOKEN后按照内置的语法顺序将TOKEN载入语法树完成语法解析。
- 语义分析
语法树装在完成后,按照语法树的顺序翻译成java虚拟机的规范格式–字节码文杰(.class)。