编译原理 —— 什么是编译

计算机是如何工作的

在这里插入图片描述

机器语言:机器语言直接用二进制代码指令表达的计算机语言,指令是用0和1组成的一串代码,可以被计算机直接理解,如上图的C706 0000 0002(以16进制书写,但在计算机中是二进制)

汇编语言:汇编语言是面向机器的程序设计语言,使用助记符(Memoni)代替操作码,用地址符号(Symbol)或标号(Label)代替地址码。如上图的MOV X,2

高级语言:高级语言是高度封装的编程语言,使用类似于数学定义或自然语言的简洁形式进行程序编写。如上图的x=2


翻译程序

翻译程序是将一种语言程序(源)转换成另一种语言程序(目标),两者在逻辑上是等价的。翻译程序分为 编译程序解释程序 两种。

  • 编译程序:由高级语言翻译生成出低级语言的目标程序,然后再让计算机执行这个目标程序,得到计算结果。
  • 解释程序:边转换边执行,不生成目标程序

因此,我们要将高级语言最终翻译成机器语言,使得计算机得以理解并执行程序。而将高级语言翻译成汇编语言或机器语言的过程,我们就称之为“编译”。


编译器在语言处理系统中的位置

  1. 预处理器
    • 把存储在不同文件中的源程序聚合在一起
    • 把称为宏的缩写语句转换为原始语句
  2. 编译器
    • 将高级语言翻译成汇编语言或机器语言
  3. 汇编器
    • 将汇编语言翻译成可重定位的机器语言
    • 若在编译器阶段已经直接将高级语言翻译成机器语言,则可以省略汇编器
  4. 加载器
    • 修改可重定位地址
    • 将修改后的指令和数据放到内存中适当的位置
  5. 链接器
    • 将多个可重定位的机器代码文件连接到一起
    • 解决外部内存地址问题

其中,可重定位:数据在内存中存放的起始位置不是固定的,起始位置+相对地址=绝对地址


编译系统的结构

在这里插入图片描述

  1. 词法分析:确定各个单词的词性
  2. 语法分析:识别句子中的各个短语
  3. 语义分析:分析语句和声明是如何构成程序的

参考地址:

https://www.icourse163.org/learn/HIT-1002123007?tid=1003246005#/learn/announce

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值