编译器与解释器原理

上一章我们已经了解到,编程语言其实就是一种我们人类易于理解的程序语言。我们用这种编程语言编写的程序就称为源代码。这些源代码是通过翻译器这么个东西,被翻译成二进制指令,从而让计算机能够执行我们的指令。

那么,这其中发挥很大作用的翻译器又是怎么回事?

编译型语言解释型语言

其实,翻译器不止一种。我们根据翻译器翻译的时机,将它分为了编译器和解释器。

相应的,编程语言也分为了编译型语言和解释型语言。

编译型语言要求将所有的源代码通过编译器转换成二进制指令,也就是生成一个可执行程序(比如Windows下的.exe文件),比如汇编语言、C语言、C++等都是编译型语言。

解释型语言,顾名思义就是将源代码一边转换,一边执行。就好像你阅读文章一样,读到哪程序执行到哪。这种方式不需要生成可执行程序,使用会更加方便,比如Python、PHP、JavaScript、MATLAB等都是解释型语言。

虽然文中对编译器和解释器讲解的比较简单,但事实上,翻译源代码的过程十分复杂,过程大致包括词法分析、语法分析、语义分析、性能优化、生成可执行文件等5个步骤,其中涉及到复杂的算法和硬件架构,这一点本文不再赘述。

操作系统

另外大家需要了解的一点是,计算机程序都是运行在操作系统中的,目前我们比较熟知的操作系统平台都有Windows、Linux、MacOS,当然这三种操作系统都不是瞬间诞生的,也都经历了操作系统几十年的发展,才完善成我们目前熟知的版本。
长时间不同发展,导致不同的操作系统平台之间底层的内部结构截然不同,也就是说能够在Windows系统运行的程序,拿到MacOS下便会无法运行,同理,能在Linux平台下执行的程序,也不能在Windows平台下执行。

另外,就算是相同的操作系统,不同的版本之间也不一定兼容。比如不能将Windows64位程序拿到Windows32位平台下运行。但反之一般都可以,这是因为64位Windows对32位程序做了兼容性处理。这也是几乎所有程序版本之间的通病,新版本可以兼容老版本,老版本兼容不了新版本。

除了程序不能跨平台使用之外,源代码也不能跨平台使用。例如C语言中,可以让程序暂停的“睡眠”函数,在Windows平台下函数名是Sleep,但在Linux平台下该函数名是sleep,首字母大小写不同。而且函数中的参数含义也不同,Sleep的参数是毫秒,sleep的参数是秒。

这是一件相当麻烦的事情,这意味着同一个软件,你不仅需要开发3种不同的源代码,还要生成3种平台的可执行程序,分别兼容Windows、Linux、Mac OS这3种平台(现在大部分软件都有不同操作系统下的版本就是因为这个原因),未来的更新维护也需要同时更新3个版本。而且,万一以后新出来个鸿蒙操作系统,是不是又需要从头开发新的版本呢?

当然,以程序员的勤劳度来看,是不会做出这么费力不讨好的事情的。事实上,程序员有各种方法来解决这个问题。

比较经典的办法,就是开发一套支持跨平台的语言。诞生于1995年的Java就是其中的引领者。目前国内Java之所以火爆,很大部分原因就是Java的跨平台特性。虽然后来微软的C#也追随了Java的脚步,但由于更新太慢,几乎都要被人遗忘了。至于C语言,C++,由于太古老,它们诞生的时候还没有操作系统呢,所以基本指望不上跨平台了。

跨平台语言运行原理

编译型语言

事实上,关于跨平台,编译型语言和解释型语言走上了不同的道路。虽然道路不同,但原理是一样的。

比如Java这门语言,之所以能够跨平台,是因为它在操作系统上层,又搭建了一个叫做Java虚拟机(Java Virtual Machine,简称 JVM)的东西。你可以把JVM理解成一个底层软件,而且针对不同的平台有不同的版本:Windows版,Linux版、MacOS版,这三个版本的JVM安装在了这三个平台上,我们编写的Java源代码会被JVM转换成字节码,字节码是可以在Java虚拟机上运行的。流程如下图:

a=>operation: Java源代码
b=>operation: Java字节码
c=>operation: JVM(Java虚拟机)
d=>operation: 不同的操作系统(Windows、Linux、MacOS)
a->b->c->d->e

Java语言运行流程

这样一来,你只需要写一份源代码就可以了,只要在操作系统中安装上对应的Java虚拟机,就可以平滑运行Java软件了。所以Java打出的口号就是:一次编译,处处运行。

a=>operation: 编译型语言源代码
b=>operation: 编译器(生成机器码)
c=>operation: 可执行文件
d=>operation: 不同的操作系统(Windows、Linux、MacOS)
e=>operation: CPU运行机器码指令

a->b->c->d->e

编译型语言运行原理

解释型语言

相对于编译型这种只有少数语言支持跨平台的语言来说,解释型语言几乎都能跨平台。“一次编写,处处运行”就是解释型语言的特点。

那么为什么解释型语言就能跨平台呢?

这一切其实都归功于解释器。

解释器其实就类似于Java虚拟机,也是编程语言与操作系统之间的中间层。官方会针对不同的平台开发不同的解释器,这些解释器会把同样的源代码在不同的操作平台下转换成对应平台“认识”的机器码,兼容了不同平台之间的差异,从而解决了跨平台的问题。

编译型和解释型语言另外一个明显的区别就是:

使用编译型语言开发的可执行程序,源代码是无法获取的,所以程序一般是闭源的。

而解释型语言由于一边转换一边执行的特性,软件下载下来的都是源代码,否则就无法运行,所以解释型语言的程序一般是开源的。

a=>operation: 解释型语言源代码
b=>operation: 解释器(生成机器码)
c=>operation: 不同的操作系统(Windows、Linux、MacOS)
d=>operation: CPU运行机器码指令

a->b->c->d

解释型语言运行原理

关于Python

Python属于解释型语言,所以运行Python程序需要安装对应平台的解释器。也就是说我们使用Python无需考虑不同平台的兼容性问题,目前常见的如Linux、Windows、MacOS、Android、PocketPC等操作系统,Python都可以完美运行!

总结

我们将编译型语言和解释型语言的差异总结如下:

类型 原理 优点 缺点
编译型语言 通过编译器将源代码转换为操作系统平台对应的机器码 编译一次,脱离编译器也能运行,效率高 可移植性差,不够灵活
解释型语言 通过解释器将源代码转换为操作系统平台对应的机器码 跨平台性好。 边转换机器码边执行,效率较低

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:编译器与解释器原理 - Python技术站

(0)
上一篇 2022年10月25日 下午7:45
下一篇 2022年10月25日 下午8:43

相关文章

  • Python多层嵌套list的递归处理方法(推荐)

    以下是详细讲解“Python多层嵌套list的递归处理方法(推荐)”的完整攻略。 在Python中,多层嵌套的列表(list)是一种常见的数据结构。在处理多层套的列表时,可以使用递归的方法来遍历和处理列表中的元素。下面是一些常见的递归处理方法。 方法一:使用递归函数 def process_list(lst): for item in lst: if isi…

    python 2023年5月13日
    00
  • python库pydantic的简易入门教程

    标题:Python库Pydantic的简易入门教程 什么是Pydantic? Pydantic是一个用于数据验证和序列化的Python库,它使用Python的类型注解进行数据验证,同时能够自动的序列化和反序列化Json,YAML和其他数据格式。Pydantic具有以下特点: 确保输入数据类型正确并自动完成类型转换 自动验证输入数据的规范性,并提供详细的错误提…

    python 2023年5月13日
    00
  • 2019 Python最新面试题及答案16道题

    以下是针对“2019 Python最新面试题及答案16道题”的完整攻略: 1. 阅读下面程序,写出输出结果 a = [1, 2, 3, 4, 5] b = a a = a[:2] print(b) 答案: [1, 2, 3, 4, 5] 解析: 首先,列表a被赋值给了变量b,此时b和a引用了同一个列表对象。然后,使用切片操作(a = a[:2])将a截取了前…

    python 2023年5月13日
    00
  • Python字符串函数strip()原理及用法详解

    Python字符串函数strip()原理及用法详解 一、strip()函数的概述 Python中的strip()函数用来去除字符串中的前后空格或特定字符,返回的是去除前后空格或特定字符后的字符串。即,该函数可以消除字符串前后的所有不可见字符。同时该函数也支持去除特定符号。 例如,我们有一个字符串为 str = ‘ this is a Python strin…

    python 2023年6月5日
    00
  • python可以美化表格数据输出结果的两个工具

    当我们使用Python进行数据处理时,经常需要通过表格来展示我们的结果,但是默认输出的表格常常会显得很凌乱和不易阅读。因此,需要使用一些工具对结果进行美化。下面介绍两个经常用来美化表格的Python库:PrettyTable和Tabulate。 PrettyTable PrettyTable模块能够将表格数据格式化为易读的格式,并支持排序、添加行和列等操作。…

    python 2023年6月5日
    00
  • Python3 pickle模块的使用方法详细介绍

    Python3 pickle模块的使用方法详细介绍 pickle模块是Python提供的一种对象序列化和反序列化的工具,能够将Python对象转换为一个可以存储到磁盘上或者进行网络传输的字符串,同时也能够将这个字符串反序列化为原来的Python对象。使用pickle模块可以方便地实现数据的持久化和传输,是Python编程中非常重要的一部分。 序列化和反序列化…

    python 2023年6月2日
    00
  • 用python做一个搜索引擎(Pylucene)的实例代码

    下面我来详细讲解用Python做一个搜索引擎(Pylucene)的实例代码的完整攻略。 Pylucene 简介 Pylucene 是 Lucene 搜索引擎的 Python 版本。Lucene 是一个高性能、全文检索库,它的主要特点是支持近实时搜索,具有高效的索引和查询操作,广泛应用于企业搜索、站内搜索等场景。 准备工作 在开始编写搜索引擎的代码之前,需要先…

    python 2023年6月6日
    00
  • python+appium实现自动化测试的示例代码

    下面是Python+Appium实现自动化测试的完整攻略,包括步骤和示例说明: 1. 确定测试环境 在开始编写测试脚本之前,需要确定好测试环境和设备信息,包括: 安装Python环境 安装Appium 配置测试手机的连接信息(包括手机型号、设备ID等) 2. 编写测试用例 在测试用例编写时,需要确定测试用例的目的和预期结果,根据应用程序的UI设计,编写脚本来…

    python 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部