`
xinklabi
  • 浏览: 1587948 次
  • 性别: Icon_minigender_1
  • 来自: 吉林
文章分类
社区版块
存档分类
最新评论

解释器与编译器的区别

 
阅读更多

来福与旺财的养牛场
来福和旺财有一个养牛场。本来养牛不是一件太难的事情,但是偏偏他俩养的牛都有特别的怪癖。奶牛阿圆只吃切成圆形的牧草,而奶牛阿方和阿三(印度来的?)分别只吃切成正方形和三角形的牧草。如果来福和旺财拿不和奶牛性格的草去喂食,阿X们不但不产奶而且还会鄙视来福和旺财。于是来福和旺财分别有了自己的主意。
来福的方案:
   
来福发明了三套大型碾碎机:圆圆碾碎机,方方碾碎机和三三碾碎机。每天收割了牧草,就分别放到这三套机器里碾碎给三头奶牛吃。但是一旦被碾碎了,这堆草就只能给某一头牛吃了。很明显阿方是不会吃给阿圆准备的草的。而且来福每天都要操作这三台机器,觉得比较麻烦。
<!--[if gte vml 1]><v:shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" path="m@4@5l@4@11@9@11@9@5xe" filled="f" stroked="f"> <v:stroke joinstyle="miter"/> <v:formulas> <v:f eqn="if lineDrawn pixelLineWidth 0"/> <v:f eqn="sum @0 1 0"/> <v:f eqn="sum 0 0 @1"/> <v:f eqn="prod @2 1 2"/> <v:f eqn="prod @3 21600 pixelWidth"/> <v:f eqn="prod @3 21600 pixelHeight"/> <v:f eqn="sum @0 0 1"/> <v:f eqn="prod @6 1 2"/> <v:f eqn="prod @7 21600 pixelWidth"/> <v:f eqn="sum @8 21600 0"/> <v:f eqn="prod @7 21600 pixelHeight"/> <v:f eqn="sum @10 21600 0"/> </v:formulas> <v:path o:extrusionok="f" gradientshapeok="t" o:connecttype="rect"/> <o:lock v:ext="edit" aspectratio="t"/> </v:shapetype><v:shape id="图片_x0020_12" o:spid="_x0000_i1030" type="#_x0000_t75" alt="点击在新窗口中浏览此图片" href="http://blog.chinaunix.net/link.php?url=http://www.turbozv.com/up/image001.png" style='width:247.5pt;height:204pt;visibility:visible;mso-wrap-style:square' o:button="t"> <v:fill o:detectmouseclick="t"/> <v:imagedata src="file:///C:\Users\CFT\AppData\Local\Temp\msohtmlclip1\01\clip_image001.png" o:title="点击在新窗口中浏览此图片" croptop="3121f" cropright="11325f"/> </v:shape><![endif]--><!--[if !vml]-->点击在新窗口中浏览此图片<!--[endif]-->
旺财的方案:
   
旺财在考察了来福的方案后,发现每天操作三台机器真的很麻烦,而且有时有的牛吃不完,有的牛不够吃时,还不能在奶牛之间调配碾碎了的牧草。所以旺财有了不同的想法:口罩型碾碎机。
<!--[if gte vml 1]><v:shape id="图片_x0020_11" o:spid="_x0000_i1029" type="#_x0000_t75" alt="点击在新窗口中浏览此图片" href="http://blog.chinaunix.net/link.php?url=http://www.turbozv.com/up/image003.png" style='width:228.75pt;height:198.75pt;visibility:visible;mso-wrap-style:square' o:button="t"> <v:fill o:detectmouseclick="t"/> <v:imagedata src="file:///C:\Users\CFT\AppData\Local\Temp\msohtmlclip1\01\clip_image003.png" o:title="点击在新窗口中浏览此图片" croptop="3121f" cropright="11930f"/> </v:shape><![endif]--><!--[if !vml]-->点击在新窗口中浏览此图片<!--[endif]-->
   
就像在图上看到的,旺财给每头奶牛装配了一台口罩碾碎机,所以三头牛完全可以在一个槽里吃草了,在吃之前口罩会自动把牧草碾碎成适合该牛食用的类型。旺财就轻松了,他每天只需要割割草就行了。
   
但是旺财被鄙视了???
   
是的,被来福鄙视了。来福观察后发现,旺财的口罩碾碎机的效率很低(因为比较小嘛)。阿圆食量大,吃来福的圆圆碾碎机的食物一个小时就饱了,但是戴着口罩吃的时候要吃十个小时!所以来福认为旺财的口罩碾碎机虽然省事,但只能喂喂小牛,完全不适合食量大的牛。
   
旺财也觉得这样做有问题,但他不想回到来福方案上,他改进了口罩方案:牧草预切割机。
<!--[if gte vml 1]><v:shape id="图片_x0020_10" o:spid="_x0000_i1028" type="#_x0000_t75" alt="点击在新窗口中浏览此图片" href="http://blog.chinaunix.net/link.php?url=http://www.turbozv.com/up/image005.png" style='width:245.25pt;height:215.25pt;visibility:visible;mso-wrap-style:square' o:button="t"> <v:fill o:detectmouseclick="t"/> <v:imagedata src="file:///C:\Users\CFT\AppData\Local\Temp\msohtmlclip1\01\clip_image005.png" o:title="点击在新窗口中浏览此图片" croptop="3511f" cropright="10872f"/> </v:shape><![endif]--><!--[if !vml]-->点击在新窗口中浏览此图片<!--[endif]-->
   
呵呵,看到预切割做了什么吗?它把牧草割得小了一些,所以需要口罩碾碎机做的事情就少多了。(当然口罩碾碎机也要作适当改进适合预切割后的牧草,所以图上用蓝色表示)阿圆以前用口罩不是要吃十个小时吗,现在两三个小时就可以了。
编译器与解释器

好的,谢谢你有耐心看到这里,经过上面那个不太恰当的例子,相信你已经相当的糊涂了。那么我们试着回到技术方面来。在上面的例子中
   
牧草 = 我们的各种编程语言,C/C++/C#, Java, Pascal, PHP, Python, Perl, Java Script等等
   
切割机 = 各种编译器
   
奶牛 = 各种CPU(不要告诉我IntelAMD哦),比如x86ARMMIPS等等
   
那你应该知道了为什么奶牛会有吃不同形状牧草的嗜好了,这个奇怪的比喻是为了表示不同的CPU接受的不同的机器语言。

对应上面的奶牛图,编译器的图是这样的
<!--[if gte vml 1]><v:shape id="图片_x0020_9" o:spid="_x0000_i1027" type="#_x0000_t75" alt="点击在新窗口中浏览此图片" href="http://blog.chinaunix.net/link.php?url=http://www.turbozv.com/up/image007.png" style='width:258.75pt;height:170.25pt;visibility:visible;mso-wrap-style:square' o:button="t"> <v:fill o:detectmouseclick="t"/> <v:imagedata src="file:///C:\Users\CFT\AppData\Local\Temp\msohtmlclip1\01\clip_image007.png" o:title="点击在新窗口中浏览此图片" croptop="5863f" cropbottom="6282f" cropleft=".0625" cropright="4681f"/> </v:shape><![endif]--><!--[if !vml]-->点击在新窗口中浏览此图片<!--[endif]-->
源代码被编译成机器码,在CPU上运行。
而解释器是这样的
<!--[if gte vml 1]><v:shape id="图片_x0020_8" o:spid="_x0000_i1026" type="#_x0000_t75" alt="点击在新窗口中浏览此图片" href="http://blog.chinaunix.net/link.php?url=http://www.turbozv.com/up/image009.png" style='width:272.25pt;height:178.5pt;visibility:visible;mso-wrap-style:square' o:button="t"> <v:fill o:detectmouseclick="t"/> <v:imagedata src="file:///C:\Users\CFT\AppData\Local\Temp\msohtmlclip1\01\clip_image009.png" o:title="点击在新窗口中浏览此图片" croptop="5444f" cropbottom="5653f" cropleft="3804f" cropright="3658f"/> </v:shape><![endif]--><!--[if !vml]-->点击在新窗口中浏览此图片<!--[endif]-->
   
用解释器很方便,只需要直接“运行”就好了,不用像C那样有编译链接的工序。
   
为什么说这些语言是跨平台的?因为你写了程序以后,如果这个平台上有这种语言的解释器,只需要拿到这个平台上直接运行就可以了。你可以理解为:解释器是在“一边编译,一边运行”,它只是把以前程序员手工做的编译过程放在了运行程序的时候进行。
   
为什么我们一般说解释器的效率比较低?你也可以想象的是,一段程序在解释器中运行时可能会被编译多次,因为每次运行到这段程序时,都会重新编译一次,这样的开销是很大的。
所以诞生了JavaC#这样的预编译语言:
<!--[if gte vml 1]><v:shape id="图片_x0020_7" o:spid="_x0000_i1025" type="#_x0000_t75" alt="点击在新窗口中浏览此图片" href="http://blog.chinaunix.net/link.php?url=http://www.turbozv.com/up/image011.png" style='width:279.75pt;height:179.25pt;visibility:visible;mso-wrap-style:square' o:button="t"> <v:fill o:detectmouseclick="t"/> <v:imagedata src="file:///C:\Users\CFT\AppData\Local\Temp\msohtmlclip1\01\clip_image011.png" o:title="点击在新窗口中浏览此图片" croptop="5862f" cropbottom="3979f" cropright="4827f"/> </v:shape><![endif]--><!--[if !vml]-->点击在新窗口中浏览此图片<!--[endif]-->
   
在运行之前,需要手动把源代码编译成中间代码(Java里叫字节码),然后在解释器中执行。
这种架构避免了上面纯解释器中编译源代码的开销,所以相对会有效率一些。
   
但是我不能骗你们,其实我画在纯解释器中的PythonPerlPHP可能都不会是真的纯解释执行的,这样实在是太没有效率。Python在运行时会生成pyc的二进制临时文件,看起来很像是预编译的结果。只有JavaScript这种真的不会写得太长的语言(Ajax请原谅我)才会采用纯解释的运行方式。

分享到:
评论

相关推荐

    PL0解释器与编译器的分离及其功能扩展

    首先,让我们了解编译器和解释器的区别。编译器是将源代码(高级语言)一次性转化为目标代码(机器语言)的程序,而解释器则是逐行读取源代码并直接执行。对于PL0语言,我们可以分别实现这两个组件来更好地理解和...

    PL0的解释器与编译器的分离

    标题中的“PL0的解释器与编译器的分离”是指在编程语言处理系统中,将PL0语言的编译器和解释器作为两个独立的组件进行设计和实现。这样的设计使得编译过程和执行过程可以分开,为理解和调试提供了便利,同时也允许更...

    Lua5.3.5解释器+编译器

    压缩包中的"Lua5.3.5"可能包含了所有这些组件,包括`lua.exe`解释器、`luac.exe`编译器以及可能的依赖文件,如动态链接库(DLLs)或其他必要的支持文件。在Windows环境下,用户可以直接运行这些文件来执行Lua脚本或...

    python解释器和编译器-win x32

    python解释器和编译器-win x32

    python解释器和编译器mac版安装包

    python解释器和编译器mac版安装包

    python解释器和编译器安装包-win x64

    python解释器和编译器安装包-win x64

    Lua5.3 源码 编译器 解释器 库文件

    官网下载的源码 然后自己生成了编译器 解释器和库文件 只需要把你的lua文件放在与lua exe同一目录然后运行lua exe 输入dofile &quot;lua文件名&quot; 回车就可以运行lua文件啦 方便新手用

    C语言中的编译器与解释器:工作原理与应用对比

    编译器和解释器是执行高级编程语言代码的两种不同机制。...了解编译器和解释器的工作原理和区别,可以帮助开发者更好地选择适合项目需求的工具。希望本文能帮助读者更好地理解编译器和解释器在C语言中的应用。

    tiny 编译器及解释器.rar

    首先,我们要明确编译器和解释器的区别。编译器是一次性将整个源代码转换成目标代码(通常为机器语言)的程序,而解释器则是逐行或逐语句地执行源代码,不生成独立的目标代码。Tiny编译器与解释器项目结合了这两种...

    C0程序编译器解释器实现

    C0程序编译器与解释器的实现是一个基础但至关重要的步骤,对于理解计算机科学中的编译原理和解析技术有着深远的意义。C0语言是一种简化的编程语言,通常用于教学目的,它帮助初学者理解高级语言如何转换为机器可执行...

    编译器与编译器生成器(C++版)

    C++的编译器生成器,如ANTLR、Flex和Bison等,是用于创建自定义编译器或解释器的工具。它们帮助开发者定义语言的语法,并自动生成相应的词法分析器和语法分析器。这样,开发者可以专注于实现语义分析和代码生成部分...

    基于Java实现的C语言编译器解释器(实现词法分析、语义分析、绘制图像与窗口建立等).zip

    将总体过程分为4个阶段,分别为Scanner(词法分析)、Paerser(语法分析)、Semantic(语义分析)、Main(绘制图形与窗口建立),全过程采用JAVA语言、递归下降子程序方法以及增量模型开发思想完成解释器。同时还为编译器增加...

    Python解释器与编译器

    Python解释器下载地址 Python的版本可以选3.5,3.7,3.8。切记,Python2与Python3不兼容。因此不要下Python2,并且开发者也声明Python2很快就会被淘汰。 Python解释器下载的顺序: 1.选择Install now 2.切记,一定要...

    详解python编译器和解释器的区别

    ### 详解Python编译器与解释器的区别 #### 引言 随着计算机技术的发展,编程语言作为连接人类思维与计算机操作的重要桥梁,其种类日益繁多。不同的编程语言有着不同的特性,这些特性往往决定了它们更适合解决哪一类...

    cmm解释器大作业

    总的来说,"cmm解释器大作业"是一个全面的编程实践,涵盖了编译器设计的核心环节,对于提升学生的编程素养和技术能力具有极大的价值。通过这个项目,学生不仅能深入理解编程语言的底层机制,还能培养出严谨的逻辑...

    oosrc.rar_C语言解释器_semantic_绘图 编译器_解释器_语法分析

    《C语言解释器:深入解析语义、绘图与编译器构建》 在计算机科学领域,编译器和解释器是将高级编程语言转换为机器可执行代码的关键工具。本资源聚焦于“oosrc.rar”,一个包含了C语言解释器实现的压缩包,其核心...

    lua5.3.5最新版安装文件(包含c源码、解释器、编译器、静态库、用户手册和一个2048游戏脚本)

    lua5.3.5最新解释器、编译器、静态库、用户手册及c源码的安装包,附加2048游戏脚本,完整实用资源,请下载。 Lua是一个小巧的脚本语言。它是于1993年开发的。 其设计目的是为了通过灵活嵌入应用程序中从而为应用...

    HBasic:具有解释器和编译器的IDE-开源

    HBasic是具有解释器和编译器的IDE,用于使用BASIC样式语言创建,执行和调试程序。 该语言包括面向对象的功能,可以编译为解释器pcode和独立的可执行文件。

    lua-5.1.4 的 lib 文件 及 解释器 编译器

    此压缩包包含的是Lua 5.1.4版本的相关文件,主要包括库文件(lib)和解释器(interpreter),以及可能的编译器工具。 ** Lua 5.1.4 库文件(lib)** 库文件是预编译的二进制模块,允许程序在运行时动态链接到Lua的...

Global site tag (gtag.js) - Google Analytics