编译原理学习 一 什么是编译程序

编译程序是一种语言翻译工具,它将源代码转换为目标代码。编译过程包括词法分析、语法分析、语义分析、中间代码生成、代码优化和目标代码生成六个阶段。词法分析识别单词,语法分析构造语法树,语义分析检查源程序的语义错误并收集类型信息。中间代码生成简化源程序,代码优化提高目标代码效率,最后目标代码生成则将中间代码转化为特定机器可执行的语言。
摘要由CSDN通过智能技术生成

一 什么是编译程序

从功能上看,编译程序就是一个语言翻译程序。语言翻译程序把一种语言书**(称作源语言)写的程序翻译成另一种语言(称作目标语言)**的等价程序。

编译程序的功能
一个程序设计语言的典型处理过程:
高级语言的处理过程

编译程序的结构

编译过程

编译过程可以划分为: 词法分析语法分析语义分析中间代码生成代码优化目标代码生成 6个阶段。

词法分析

从左到右一个字符一个字符的读入源程序,对构成要换程序的字符流进行扫描和分解,从而识别出一个个单词。
在这里插入图片描述

语法分析

在词法分析的基础上将单词序列分解成各类语法短语。语法短语也成为语法单位,可以表示成语法树。
id1 := id2 + id3 * 10 为例,语法树如下:
在这里插入图片描述

语义分析

语义分析是审查源程序有无语义错误,为代码生成阶段收集类型信息。

中间代码生成

在完成语法分析和语义分析之后,将源程序编程中间代码,所谓中间代码就是一种结构简单、含义明确的记号系统,这种记号系统可以设计成多种多样的形式。遵循原则:容易生成,容易翻译成目标程序。

代码优化

对中间代码进行变换和搞糟,使生成的目标代码更为高效。 就是化简

目标代码生成

把中间代码变换成特定机器上的绝对指令代码或可重定位的指令代码或汇编指令代码。
在这里插入图片描述

解释程序

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值