1.3编程语言概述(重点:编译型和解释型)

1.3-编程语言概述

这一节简单了解一下计算机语言的发展史,计算机是一个冷冰冰的机器,赋予其灵魂的就是编程语言!

一、机器语言(1940年之前)

从上面的章节可以看出,计算机只能看懂0和1的二进制码,所以最早诞生的编程语言就是机器语言。机器语言非常晦涩难懂,例如在做计算的时候,我们要写768,必须写1100000000,计算才能看懂,其它的数以此类推,如果再做加减乘除就会变的更加的麻烦,如果要输出一个“中国就是好”,可能要几百个01的组合,看都没法看,更不要说去查找错误了!归纳一下,机器语言的问题就是太难写,太难读,太难改!

二、汇编语言(20世纪40年代)

后面出现了汇编语言,汇编语言虽然解决了机器语言读写复杂的问题,但本质上还是面向机器的,写这个语言需要我们去了解计算机底层的知识。例如CPU指令,寄存器,段地址等底层的实现细节,编写也很复杂。

三、高级语言(20世纪50年代)

为了解决汇编语言的问题,高级语言应运而生,高级语言的特点就是让程序员不再去关注底层,而是把重心放到业务上来!

计算机不能直接的理解高级语言,只能直接理解机器语言,所以必须要把高级语言翻译成机器语言,计算机才能执行高级语言的编写的程序。翻译的方式有两种,一个是编译,一个是解释。两种方式只是翻译的时间不同。编译型语言是指它常用的执行机制是使用一个“编译器”来编译成机器语言,然后你就可以直接运行(执行)这个编译成的“可执行文件”,例如C语言。你也可以为解释性语言(如AutoHotkey脚本语言)写个编译器来编译,这样它就成了“编译语言”。 解释性语言是指它常用的执行机制是使用一个“解释器”来执行,解释器对于程序是一句一句“翻译”成机器语言来一句一句执行,例如AutoHotkey脚本语言。不管是解释性语言还是编译型都可编译或解释,前提是有这样的编译器或解释器(比如你自己写一个),找不到这样的编译器你当然不能编译对于语言本身来说,各种编程语言本质没什么不同。所谓的“解释性”和“编译”指的是执行机制上的不同。

       拓展:解释性语言和编译型语言的优缺点

编译型语言:

  • 编译型语言最大的优势之一就是其执行速度。用C/C++编写的程序运行速度要比用Java编写的相同程序快30%-70%。编译型程序比解释型程序消耗的内存更少。不利的一面——编译器比解释器要难写得多。编译器在调试程序时提供不了多少帮助——有多少次在你的C语言代码中遇到一个“空指针异常”时,需要花费好几个小时来明确错误到底在代码中的什么位置。可执行的编译型代码要比相同的解释型代码大许多。例如,C/C++的.exe文件要比同样功能的Java的.class文件大很多。编译型程序是面向特定平台的因而是平台依赖的。编译型程序不支持代码中实现安全性——例如,一个编译型的程序可以访问内存的任何区域,并且可以对你的PC做它想做的任何事情(大部分病毒是使用编译型语言编写的)。由于松散的安全性和平台依赖性,编译型语言不太适合开发因特网或者基于Web的应用。

解释型语言:

  • 解释型语言提供了极佳的调试支持。一名Java程序员只需要几分钟就可以定位并修复一个“空指针异常”,因为Java运行环境不仅指明了异常的性质,而且给出了异常发生位置具体的行号和函数调用顺序(著名的堆栈跟踪信息)。这样的便利是编译型语言所无法提供的。另一个优势是解释器比编译器容易实现。解释型语言最大的优势之一是其平台独立性。解释型语言也可以保证高度的安全性——这是互联网应用迫切需要的。中间语言代码的大小比编译型可执行代码小很多。平台独立性,以及严密的安全性是使解释型语言成为适合互联网和Web应用的理想语言的2个最重要的因素。解释型语言存在一些严重的缺点。解释型应用占用更多的内存和CPU资源。这是由于,为了运行解释型语言编写的程序,相关的解释器必须首先运行。解释器是复杂的,智能的,大量消耗资源的程序并且它们会占用很多CPU周期和内存。由于解释型应用的decode-fetch-execute(解码-抓取-执行)的周期,它们比编译型程序慢很多。解释器也会做很多代码优化,运行时安全性检查;这些额外的步骤占用了更多的资源并进一步降低了应用的运行速度。

给TA捐赠
共{{data.count}}人
人已捐赠
教程

1.2 计算机结构和运行原理(重点:冯诺依曼结构和程序运行过程)

2019-12-18 21:04:43

其他教程

电脑软件安装过程文档

2019-12-21 9:47:29

2 条回复 A文章作者 M管理员
  1. user14582

    不错o

  2. 233

    miao a

个人中心
购物车
优惠劵
有新私信 私信列表
搜索