博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
凭啥Java的运行环境称虚拟机,Python的只能称解释器
阅读量:5735 次
发布时间:2019-06-18

本文共 1322 字,大约阅读时间需要 4 分钟。

看到Stackoverflow上有个问题在讨论Java和Python的对比,其中就有人问答为啥Java的运行环境被称之为JVM,而Python的只能叫做Interpreter。

这个问题估计想过的人不多,先找维基百科看一下虚拟机的定义。

虚拟机的定义有2个,一种是类似Vmware的系统虚拟机,另一种是虚拟机称之为程序虚拟机,诸如JVM,CLR就是最常见到的虚拟机。

程序虚拟机也称作托管运行时环境,运行这个虚拟机时,就好比普通的OS中的一个进程。当这个进程启动时,虚拟机启动,当进程销毁时,虚拟机销毁。使用虚拟机的目的就是提供一个和平台无关的编程环境。

JVM中的执行引擎只能处理编译后的Java字节码,字节码处理引擎其实包含一个字节码解释器和一个JIT编译器(和.net的CLR中JIT差别很大),解释器逐条的执行字节码指令,速度稍慢。JIT编译器则会将热点代码编译缓存起来,因此执行速度加快。

解释器的概念比较简单,它可以将代码翻译,并运行,不需要经过编译,JVM中的解释器正式这样的,JVM中解释的就是字节码。解释器运行程序的方法有3种:

  1. 直接运行高级编程语言(如Shell内置的解释器)

  2. 转换高级编程语言码到一些有效率的字节码(Bytecode),并运行这些字节码

  3. 以解释器包含的编译器对高级语言编译,并指示处理器运行编译后的程序(例如:JIT)

其中Python的解释器就是属于第二种,Python代码在首次运行时,它会将Python代码编译成字节码,如果可以的话,它会将这个字节码保存到.pyc文件中,这样下次启动的时候就不会再编译这些代码而是直接解释运行字节码。事实上,这种机制正在模糊解释器和编译器之间的界限,或者说是模糊了解释型语言和编译型语言的界限。

通过JVM和解释器的概念澄清,似乎还是不明白为啥JVM就被称为虚拟机,JVM中有运行的是字节码,它可能直接被解释执行,也可能被再次编译成目标语言,Python中的解释器也会先预编译Python代码为字节码,再解释执行。那么到底有啥区别?

很多人参与了讨论,分别从不同的角度去阐述区别。

有人认为虚拟机是和语言无关的,JVM为例,除了Java之外,Scala,Clojure,甚至Python借助于Jython工具,也可以运行在JVM上,而没听说什么语言能有Python解释器解释执行,除了Python。

也有人从语言的类型上,Java为静态类型的语言,而Python为动态语言。这使得Java字节码既可以被解释执行也可以被编译成机器指令再执行。而Python则复杂多了,它虽然让程序员可以不去关注变量的类型,但解释器不得不去推断数据类型,这一定程度上影响性能。

还有观点认为解释器是一个历史遗留术语,现代语言中虚拟机和解释器的分界已经很模糊甚至不存在。

事实上,笔者在《Learning Python》一书中,看到把作者把Python的解释器称为PVM,基于这个事实来讲,本人更认同的是解释器和虚拟机的区别正在越来越小,已经是我中有你,你中有我的地步。独立的分割来看,可能还能区分这几步是解释器行为,这几步是虚拟机的行为,但是作为一个整体来看,两者的区别确实没那么明显。

转载地址:http://ztrwx.baihongyu.com/

你可能感兴趣的文章
一个引号导致1个小时网站打不开
查看>>
普林斯顿算法part1--堆--笔记 2018年4月20到4月27
查看>>
POJ1273 Drainage Ditches (网络流)
查看>>
hiho一下第133周 2-SAT·hihoCoder音乐节(2-SAT)(强连通)
查看>>
转换...
查看>>
allegro中出光绘文件遇到问题的解决办法
查看>>
/etc/alternatives/xinputrc备份
查看>>
计算机专业课系列之一:漫谈计算机组成原理和编程语言
查看>>
第三章:授权
查看>>
node-odata: ASP.NET WEB API OData的替代品
查看>>
Java序列化流-ObjectOutputStream、ObjectInputStream
查看>>
【2012 - 百度之星资格赛 - I:地图的省钱计划】
查看>>
图书馆图书检索的小技巧
查看>>
系统快捷键被谁占用? 查看工具
查看>>
Clover 3 --- Windows Explorer 资源管理器的一个扩展,为其增加类似谷歌 Chrome 浏览器的多标签页功能。...
查看>>
[leetcode-264-Ugly Number II]
查看>>
uva-10670-贪心
查看>>
OCP 062大量考试新题(2019年)-12
查看>>
Django~待解决的问题
查看>>
C_求最大连续子序列和
查看>>