编译原理 第1章:概述

本文详细阐述了编译程序的工作原理,包括词法分析、语法分析、语义分析和中间代码生成,以及优化和目标代码产生过程。讨论了不同语言和机器间的编译策略,并区分了编译程序与解释程序。
摘要由CSDN通过智能技术生成

1. 什么叫编译程序

  1. 源程序:用汇编语言或高级语言编写的程序称为源程序(无法直接执行)。

  2. 目标程序:用目标语言所表示的程序。可以是
    - 介于源语言和机器语言之间的某种“中间语言”
    - 某种机器的机器语言
    - 某种机器的汇编语言

  3. 翻译程序:将某一种语言程序(称为源语言程序)等价地转换为另一种语言程序(称为目标语言程序)的程序称为翻译程序。它是指各种语言的翻译器,是汇编程序、编译程序以及各种变换程序的总称。
    在这里插入图片描述

  4. 源程序、翻译程序、目标程序三者关系:
    在这里插入图片描述

  5. 汇编程序
    若源程序用汇编语言书写,经过翻译程序得到用机器语言表示的程序,这时的翻译程序就称之为汇编程序,这种翻译过程称为“汇编”(Assemble)

  6. 编译程序
    若源程序是用高级语言书写,经加工后得到汇编语言或机器语言这样的目标程序,这种翻译过程称“编译”(Compile)(把某一种高级语言程序等价地转换成另一种低级语言程序(如汇编语言或机器语言程序)的程序
    在这里插入图片描述

汇编程序与编译程序都是翻译程序主要区别是加工对象的不同。由于汇编语言格式简单,常与机器语言之间有一一对应的关系,汇编程序所要做的翻译工作比编译程序简单得多。

  1. 解释程序(interpreter)
    把源语言写的源程序作为输入,但不产生目标程序,而是边解释边执行源程序本身
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

2. 编译过程及编译程序构造

在这里插入图片描述
总体框架:
在这里插入图片描述

2.1 词法分析

  1. 任务: 输入源程序,对构成源程序的字符串进行扫描和分解,识别出一个个单词符号,并以某种编码形式输出。
  2. 依循的原则词法规则(构词规则)
  3. 描述工具正规式与有限自动机
    在这里插入图片描述

2.2 语法分析

  1. 任务:在词法分析的基础上,根据语言的语法规则(即语言的文法),分析并识别出各种语法成分,如表达式、各种说明、各种语句、过程、函数等,并进行语法正确性检查。
  2. 依循的原则语法规则
  3. 描述工具:上下文无关文法
    在这里插入图片描述
    在这里插入图片描述

2.3 语义分析和中间代码的产生

  1. 任务
    - 对各类不同语法范畴按语言的语义进行初步翻译,对识别出的各种语法成分进行语义分析,并产生相应的中间代码
    - 中间代码:一种介于源语言和目标语言之间的中间语言形式,中间代码的形式编译程序设计者可以自己设计,常用的有四元式、三元式、逆波兰表示、树形结构等

  2. 依循的原则:语义规则(属性文法)
    在这里插入图片描述
    在这里插入图片描述

2.4 优化

  1. 任务:对于前一阶段产生的中间代码进行加工变换(等价、高效、合算),以期在最后阶段产生更高效的目标代码。
    2 . 依循的原则:程序的等价变换规则
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

2.5 目标代码产生

  1. 任务: 把中间代码变换成特定机器上的目标代码。
  2. 依赖于硬件系统结构和机器指令的含义
  3. 目标代码三种形式:
    • 绝对指令代码: 可直接运行
    • 可重新定位指令代码: 需要连接装配
    • 汇编指令代码: 需要进行汇编
  4. 由中间代码很容易生成目标程序(地址指令序列)。这部分工作与机器关系密切 ,所以要根据机器进行。在做这部分工作时(要注意充分利用累加器),也可以进行优化处理。
    在这里插入图片描述
    在这里插入图片描述

2.6 编译程序的逻辑结构

在这里插入图片描述

2.7 遍(PASS)

:对源程序(包括源程序中间形式)从头到尾扫描一次,并做有关的加工处理 ,生成新的源程序中间形式或目标程序,通常称之为一遍
在这里插入图片描述
一遍扫描即可完成整个编译工作的称为一遍扫描编译程序,其结构为:
在这里插入图片描述

2.8 前端和后端

根据编译程序各部分功能,将编译程序分成前端后端。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3. 编译程序的生成

在这里插入图片描述

3.1 第一种情况:同一台机器,不同的语言

在这里插入图片描述

3.2 第二种情况:同一种语言,不同的机器

在这里插入图片描述

3.3 第三种方案:自展

在这里插入图片描述
在这里插入图片描述

  • 28
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赵远疴

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值