1.编译程序编译程序是一种翻译程序,它将高级语言所写的源程序翻译成等价的机器语言或汇编语言的目标程序
2.词 法 分 析 ( Lexical analysis 或 Scanning ) 和 词 法 分 析 程 序(Lexical analyzer 或 Scanner)词法分析阶段是编译过程的第一个阶段
这个阶段的任务是从左到右一个字符一个字符地读入源程序,即对构成源程序的字符流进行扫描然后根据构词规则识别单词(也称单词符号或符号)
词法分析程序实现这个任务
词法分析程序可以使用 lex 等工具自动生成
3.语 法 分 析 ( Syntax analysis 或 Parsing ) 和 语 法 分 析 程 序(Parser) 语法分析是编译过程的一个逻辑阶段
语法分析的任务是在词法分析的基础上将单词序列组合成各类语法短语,如“程序”,“语句”,“表达式”等等
语法分析程序推断源程序在结构上是否正确
源程序的结构由上下文无关文法描述
4.语义分析(Syntax analysis)及中间代码生成语义分析是编译过程的一个逻辑阶段
语义分析的任务是对结构上正确的源程序进行上下文有关性质的审查, 进行类型审查
例如一个 C 程序片断:int arr[2],b;b = arr * 10; 源程序的结构是正确的
语义分析将审查类型并报告错误:不能在表达式中使用一个数组变量,赋值语句的右端和左端的类型不匹配
语义分析时,根据语句的含义,可对它进行翻译,用另一种语言形式(比源语言更接近于目标语言的一种中间代码或直接用目标语言)来描述这种语义
5.代码优化代码优化的任务是对前阶段产生的中间代码进行等价变换或改造,以期获得更为高效的,即省时间和空间的代码
6.目标代码生成目标代码的生成的任务是将中间代码变换成特定机器上的绝对指令代码或可重定位的指令代码或汇编指令代码
7.遍8.前端(Fron