赞
踩
词法分析(lexical analysis or scanning):自动分词,词性标注。
从左到右扫描将一个一个字符读入源程序,对构成源程序的字符流进行扫描和分解,从而识别一个单词。
语法分析(syntax analysis):在词法分析的基础上,将单词分解成各类语法词语,并表示成"语法树"。判断由词构成的短语的排列顺序是否符合对应编程语言的语法。
语法分析特点:
1.每一种“高级语言”都有自己的语法规则
2.每一种“高级语言”的编译(解释)程序都将一定将他的语法规则内嵌在其中。
语义分析(semantic analysis):按照语法树的层次关系和先后顺序,进行类型审查,审查每个算法是否符合语言规范,不符合时应报告错误。(类型审查,作用范围检查)类型分析如,java语言中,public,private,protected的区别
特点:分为静态语义分析和动态语义分析,并且静态语义分析可以在编译时被实现,而动态的则不可以。
中间代码生成:在语法和语义分析完成后,将源程序变换成一种“内部表示形式”,该代码是一种简单的记号系统,三元组或者四元组。
代码优化:对中间代码进行变换,使代码更加高效。
目标代码生成:将中间代码变换成特定机器上的绝对指令或者可重定位的汇编指令代码。主要与硬件系统和指令含义有关。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。