编译原理 —— 什么是编译

计算机是如何工作的

编译原理 —— 什么是编译_第1张图片

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

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

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


翻译程序

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

  • 编译程序:由高级语言翻译生成出低级语言的目标程序,然后再让计算机执行这个目标程序,得到计算结果。
编译原理 —— 什么是编译_第2张图片
  • 解释程序:边转换边执行,不生成目标程序

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


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

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

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


编译系统的结构

编译原理 —— 什么是编译_第4张图片

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

参考地址:

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

你可能感兴趣的:(编译原理)