‘壹’ 编译器常用的8种优化方法
常量传播
在编译期,若能直接计算出结果的变量(通常为常量),编译器将用结果常量替换该变量。例如:
将变量x替换为常量1。
常量折叠
多个变量的计算在编译期间可能可以合并为一个变量的计算,以消除冗余。例如:
合并多个变量的计算为一个变量的一级计算。
复写传播
编译器用一个变量替换两个或多个相同的变量,以消除冗余。例如:
将两个变量y和x替换为一个变量x。
公共子表式消除
已计算过的表达式在当前上下文中未发生变化时,编译器可判断其无需再次计算,以节省性能。例如:
消除重复的计算。
无用代码消除
编译器会移除无法执行或无意义的代码,如return语句后的代码和变量自我赋值。例如:
移除无用代码。
数组范围检查消除
在动态类型安全语言中,如Java,编译器在访问数组元素前会进行越界检查。通过数据流分析,如果变量值在指定范围内,编译器可消除不必要的性能损耗。例如:
优化数组访问检查。
方法内联
将简短的函数代码直接插入其调用处,以减少调用开销。这可通过C++的inline关键字实现,编译器也可自动执行。例如:
将函数代码内联。
逃逸分析
对象如果在方法之外被引用,则被视为逃逸。编译器通过分析对象的作用域,优化内存分配。若确定对象不逃逸,将其在栈上分配,节省内存管理和垃圾回收的开销。例如:
优化对象内存分配策略,减少内存管理负担。
‘贰’ C编译程序的工作过程可以划分为哪五个阶段
【答案】:C
编译程序的工作过程一般划分为五个阶段:词法分析、语法分析、语义分析、优化、目标代码生成。( 1 )词法分析:也就是从左到右一个一个的读入源程序,识别一个单词或符号,并进行归类。( 2 )语法分析: 在词法分析的基础上,将单词序列分解成各类语法短语,如“程序”,“语句”,“表达式”等。( 3 )语义分析:审查源程序是否有语义的错误,当不符合语言规范的时候,程序就会报错。( 5 )代码优化:这个阶段是对前阶段的中间代码进行变换或改造,目的是使生成的目标代码更为高效,即节省时间和空间。 ( 6 )目标代码生成:也就是把优化后的中间代码变换成指令代码或汇编代码。 词法分析和语法分析本质上都是对源程序的结构进行分析。
‘叁’ 代码优化的分类
编译过程中可进行的优化可按阶段划分:优化可在编译的不同阶段进行,分为中间代码一级和目标代码一级的优化。可按优化涉及的程序范围划分:对同一阶段,分为局部优化,循环优化和全局优化. 进行优化所需要的基础是对代码进行数据流分析和控制流分析。如划分DAG,查找循环,分析变量的定值点和引用点等等。最常用的代码优化技术有删除多余运算,循环不变代码外提,强度削弱,变换循环控制条件,合并已知量与复写传播,以及删除无用赋值等等。
静态网页与动态网页主要根据网页制作的语言来区分:
·静态网页使用语言:HTML(超文本标记语言)
·动态网页使用语言:HTML+ASP或HTML+PHP或HTML+JSP等。
网站源码可以分为动态源码和静态源码:
·动态源码:ASP、PHP、JSP、.net、CGI等等,动态源码最大的特点就是能够和用户之间互动。
·静态源码:html、Flash、JavaScript、VBScript等等。
‘肆’ 应用编译优化三种模式
应用编译优化三种模式分别是:编译时间优化模式、执行时间优化模式和代码大小优化模式。
1、编译时间优化模式:关注编译速度的提升,以缩短应用程序高脊的编译时间为目标。在这种模式下,编译器会减少编译时间,会降低应用程序的执行效率。
2、执行时间优化模式:关注应用程序的执行效率,以提高应用程序的性能为目标。在这种模式下,编译器会优化应用程序的代码,以提高执行效率,会增加编译时间。
3、代码大小优化模式:关注应用程序的大小,以减小应兆培用程序的体积为目标。族念唯在这种模式下,编译器会减小应用程序的代码大小,以减小应用程序的体积,会降低应用程序的执行效率。