第十章:早期(编译期)优化
1:编译过程
com.sun.tools.javac.main.JavaCompiler是编译的入口,编译过程的主体代码步骤如下:
1:标注---attribute
2:数据流分析---flow
3:解语法糖---desugar
4:生成字节码---generate
一:解析与填充符号表
1:词法、语法分析----由com.sun.tools.javac.parser.Scanner类来实现;语法分析类----com.sun.tools.javac.parser.Parser类来实现;抽象语法树----com.sun.tools.javac.tree.JCTree类来表示;
2:填充符号表-----com.sun.tools.javac.comp.Enter类实现;
3:注解处理器---com.sun.tools.javac.processing.JavacProcessingEnvironment类的doProcessing方法生产一个新的JavaCompiler对象进行处理;
4:语法分析与字节码生成
A:标注检查---com.sun.tools.javac.comp.Attr类和com.sun.tools.javac.comp.Check类来实现;
B:数据及控制流分析 ----com.sun.tools.javac.comp.Flow类来实现;
C:解语法糖(语法糖包括:泛型、变长参数、自动装箱拆箱、遍历循环等)---com.sun.tools.javac.comp.TransTypes类和com.sun.tools.javac.comp.Lower类的desugar()方法来实现;
D:字节码生成---com.sun.tools.javac.jvm.Gen类来实现; 例如:包装和还原方法----Integer.valueOf()/Integer.intValue()
5:自定义应用场景:checkStyle、FindBus、Klocwork等校验工具;
A:定义XXXCheckProcessor类,继承AbstractProcessor;
B:编译XXXCheckProcessor类
C:运行与测试:javac -processor XXXCheckProcessor XXX/xxx.java进行对xxx.java进行规范检查
第十一章 晚期(运行期)优化
一:目标:
A:为何HotSpot虚拟机要使用解释器与编译器并存的架构?
技巧一:使用参数-Xint强制虚拟机运行于“解析模式/Interpreted Mode”,这时编译器不介入工作
技巧二:使用参数-Xcomp强制虚拟机运用于“编译模式/Compiled Mode”,优先采用编译方式执行,解释器仍然要在编译无法进行的情况下介入执行过程。
jdk1.7以前需要使用-XX:+TieredCompilation参数来手动开启分层编译策略,不开启默认运行在Server模式;
备注:
检查是否为“热点代码”的行为叫“热点探测”。热点探测方法有如下:
a:“踪迹/Trace的热点探测”
b:FireFox里的TraceMonkey和Dalvik里新的JIT
c:虚拟机中的热点探测判定方式有如下两种,其中HotSpot虚拟机采用的为“基于计数器的热点探测”:
B:为何HotSport虚拟机要实现两个不同的即时编译器JIT?
是为了进行分层编译策略;
C:程序何时使用解释器执行?何时使用编译器执行?
D:那些程序代码会被编译为本地代码?如何编译本地代码?
E:如何从外部观察即时编译器的编译过程和编译结果?