Compiler and Interpreter(编译器和解释器)

栏目: 服务器 · 编程工具 · 发布时间: 5年前

内容简介:在计算机的世界中,一个Programmer多多少少有听说过编辑器,解释器,机器码,字节码这些名词, 现在我们稍微深入问一问:本文的目的就是为了理清这些问题.计算机的代码根据封装程度的高低可以分为以下几类(从低到高):

在计算机的世界中,一个Programmer多多少少有听说过编辑器,解释器,机器码,字节码这些名词, 现在我们稍微深入问一问:

  • 这些名词分别表示的是什么?
  • 编辑器和解释器是如何运行?
  • 它们之间又有什么联系呢?

本文的目的就是为了理清这些问题.

目录

Type of code(代码的类型)

计算机的代码根据封装程度的高低可以分为以下几类(从低到高):

  • Microcode (微码): 微码是 一种直接控制CPU的代码 , 通过将机器指令与相关的电路实现分离, 使得机器指令可以更自由的进行设计与修改,而不用考虑到实际的电路架构.(传统架构CPU的操作直接写死在电路板上,需要物理改动才能修改).
    • 也被称为 firmware (固件).
    • 通常存放在ROM上,不开放修改.
    • 仅适用于其设计的特定硬件.
    • 处于 软件层面的最底层 .
  • Machine code (机器码): 可以由CPU直接执行的代码.
    • 在CISC架构的电脑上会被转化为机器码来执行.
    • 在RISC架构的电脑上直接执行.
  • Bytecode (字节码): 通常指的是 已经经过编译 ,需要解释器翻译后才能成为机器码的 中间代码 . 如 Java 字节码.
    • 是为了解释器的高效执行而设计.
    • 可跨平台.

Level of Programming Language(编程语言的层级)

编程语言根据 对机器语言的抽象(封装)程度 可以分为两类:

  • Low-level programming language (低级编程语言): 不提供或jin仅提供很少的封装,接近机器语言.
    • 一般指 Machine language (机器语言)和 Assembly language (汇编语言).
    • 代码通常只能在特定平台上执行.
    • 执行效率高.
    • 可阅读性差.
    • 开发效率低.
  • High-level programming language (高级编程语言): 高度封装了机器语言, 需要编译器或解释器转化成机器码才能执行. 如: C,C++,Java,Python等.
    • 执行效率较低.
    • 可读性好.
    • 开发效率高.

汇编语言的代码需要由汇编器(assembler)将代码转为机器码才能执行,也可以认为是高级语言.

如下图:

Compiler and Interpreter(编译器和解释器)

图片来自: Quora: What are the different types of programming languages?

用高级语言编写的程序要么由某种解释器直接执行,要么由编译器(以及汇编程序和链接程序)转换成机器代码, 然后由CPU执行.

下面来介绍编译器和解释器.

Compiler(编译器)

编译器是一个将一种编程语言的代码翻译(translate)为另外一种编程语言的代码的计算机程序. 通常指将高级语言的代码翻译为低级语言的代码.

主要目的是将便于人编写,阅读,维护的高级语言的代码翻译为计算机能解读,运行的机器码.

编译器还有以下几类:

  • cross-compiler (交叉编译器): 翻译输出的代码可以运行于不同的平台(不同的CPU或操作系统).
  • bootstrap compiler : 由要编译的输入语言编写的编译器,它初始核心版本由其他语言生成(一般是汇编语言).
  • decompiler (逆编译程序): 将低级语言的代码翻译为高级语言的代码.
  • source-to-source compiler (源码到源码编辑器): 将一种高级语言代码翻译成另外一种高级语言的代码.

编译器的工作流程

一个编译器的工作流程一般会包括以下几个步骤(顺序执行):

  • preprocessing
  • lexical analysis
  • parsing
  • semantic analysis (syntax-directed translation)
  • conversion of input programs to an intermediate representation
  • code optimization
  • code generation

如下图:

Compiler and Interpreter(编译器和解释器)

图片来自: The Thing from another World


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Approximation Algorithms

Approximation Algorithms

Vijay V. Vazirani / Springer / 2001-07-02 / USD 54.95

'This book covers the dominant theoretical approaches to the approximate solution of hard combinatorial optimization and enumeration problems. It contains elegant combinatorial theory, useful and inte......一起来看看 《Approximation Algorithms》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试