什么是SUN,有什么用

什么是SUN,有什么用,第1张

云计算(cloud computing),分布式计算技术的一种,其最基本的概念,是透过网络将庞大的计算处理程序自动分拆成无数个较小的子程序,再交由多部服务器所组成的庞大系统经搜寻、计算分析之后将处理结果回传给用户。透过这项技术,网络服务提供者可以在数秒之内,达成处理数以千万计甚至亿计的信息,达到和“超级计算机”同样强大效能的网络服务。

目录

现实运用

起源

特性

趋势

云计算

魔毯

云计算中的村

一线希望

消除自己的困惑

企业接受云计算服务

云计算市场将快速增长

可靠性和安全性问题

寻求折中方案

现实运用

起源

特性

趋势

云计算

魔毯

云计算中的村

一线希望

消除自己的困惑

企业接受云计算服务

云计算市场将快速增长

可靠性和安全性问题

寻求折中方案

展开

编辑本段现实运用最简单的云计算技术在网络服务中已经随处可见,例如搜寻引擎、网络信箱等,使用者只要输入简单

云技术

指令即能得到大量信息。 未来如手机、GPS等行动装置都可以透过云计算技术,发展出更多的应用服务。 进一步的云计算不仅只做资料搜寻、分析的功能,未来如分析DNA结构、基因图定序、解析癌症细胞等,都可以透过这项技术轻易达成。 稍早之前的大规模分布式计算技术即为“云计算”的概念起源 编辑本段起源IT专家网的解释: “云计算”(Cloud Computing)是分布式处理(Distributed Computing)、并行处理(Parallel Computing)和网格计算(Grid Computing)的发展,或者说是这些计算机科学概念的商业实现。许多跨国信息技术行业的公司如IBM、Yahoo和Google等正在使用云计算的概念兜售自己的产品和服务。 云计算这个名词可能是借用了量子物理中的“电子云”(Electron Cloud),强调说明计算的弥漫性、无所不在的分布性和社会性特征。量子物理上有“电子云(electron cloud)”,在原子核周围运动的电子不是一个经验世界的轨道例如像天体一样的运行轨道,而是弥漫空间的、云状的存在,描述电子的运动不是牛顿经典力学而是一个概率分布的密度函数,用薛定谔波动方程来描述,特定的时间内粒子位于某个位置的概率有多大,这跟经典力学的提法完全不同。 编辑本段特性电子云有以下特性,概然性、弥漫性、同时性等等,云计算可能的确是来自电子云的概念,前几年就有所谓“无所不在的计算”,IBM有一个无所不在的计算叫“Ubiquitous “,MS(Bill)不久也跟着提出一个无所不在的计算“Pervade“,现在人们对无所不在的计算又有了新的认识,现在说是”Omnipresent “。但是,云计算的确不是纯粹的商业炒作,的确会改变信息产业的格局,现在许多人已经用上了Google Doc和Google Apps,用上了许多远程软件应用如Office字处理而不是用自己本地机器上安装这些应用软件,以后谁还会花钱买Office软件呢还有许多企业应用如电子商务应用,例如要写一个交易程序, Google的企业方案就包含了现成的模板,一个销售人员根本没学习过高级语言程序设计(如用Netbeans 编程)也能做出来。这种计算和产业动向是符合开源精神的,符合SaaS(Software as a Service)趋势。 现在有这样的说法,当今世界只有五台计算机,一台是Google的,一台是IBM的,一台是Yahoo的,一台是Amazon的,一台是Microsoft的,因为这五个公司率先在分布式处理的商业应用上捷足先登引领潮流。Sun公司很早就提出说“网络就是计算机”是有先见之明的。 Adaptive In Organizations的解释 : “Computing in the cloud” is one name for services that run in a Web browser and store information in a provider’s data center — ranging from adaptations of familiar tools such as email and personal finance to new offerings such as virtual worlds and social networks 编辑本段趋势云计算“云计算”是一个很时尚的概念,它既不是一种技术,也不是一种理论。准确说,云计算仅描述了一类棘手的问题,因为现在这个阶段,“计算与数据”跷跷板的平衡已发生变化,即已经到“移动计算要比移动数据要便宜的多(Moving computation is cheaper than moving data)”。 “数据”变得越来越臃肿,用经济的眼光看,“数据”应该“固定”下来。想像一下,复制1PiB(1PiB = 1024TiB)数据的成本以及存储这些数据的成本,数据变来变去而导致的“一致性”问题。诸如搜索、推荐和社会关系网络等这些“新兴”的服务是很耗费“数据”的,例如,看似一个简单搜索请求,却依赖于一个规模极为庞大的索引数据,处理后输出却很小。输入输出的数据规模远远小于计算的数据处理规模,几百个KiB相对几个PiB,保守点“1 : 1000,000”。 比例问题还好理解,然而问题关键却是云内的数据与数据之间的关系,即“数据的划分问题”。尽管“分而治之”是一个古老的原则,而且分布计算也已经发展了四十多年,然而对这一点,我们的认识依然浅的很。 “云计算”代表了一个时代需求,反映了市场关系的变化,谁拥有更为庞大的数据规模,谁就可以提供更广更深的信息服务,而软件和硬件影响相对缩小。 按照云计算的最普通的和最雄心勃勃的解释,它的目标是把一切都拿到网络上。云就是网络。网络就是计算机。 当如此众多的机构分布在全国各地和世界各地的时候,当如此众多的人在移动中或者在家里工作的时候,为什么不把你的一些数据和处理需求交给第三方,使用手机、移动电脑或者其它设备访问在整个网络上的一切东西呢你的数据将由口令保护,就像在本地网络上一样并且能够在整个网络上加密。这个处理任务能够让第三方虚拟化计算机农场完成,最大限度地使用处理器的能力,大量减少机构和更广泛的团体的碳排放量。 云计算是使用与日益增长的Linux、高性能计算和虚拟化等有关的技术实现的一个领域。对于IBM和惠普等公司来说,大型计算机的复苏和刀片式服务器的发展(这两者都要归功于Linux的应用)以及数据中心在能力、数据和处理器利用率方面的效率已经使云计算成为现实。 魔毯这是一个迷人的想法。在云中或者在整个网络上的计算能够带来许多理论上和实践上的优势。数据中心耗费资金可以分别用于企业的其它部门。资金不仅要用于硬件上,而且还要用于系统维护、待机时间、没有使用的处理和存储容量、安全的担心、能源账单、升级和人员开支。甚至这个机构的每一个员工的办公桌上的每一个台式电脑都会对这个机构的现金流量产生不成比例的影响,不仅是最初的硬件投资,而且还有软件许可证开支和升级硬件以便适应软件要求的开支。跟踪随机存储在机构内部的某一台电脑上的数据也是很困难的,而且这种数据也许会永远从公司的知识库中消失。每一台这种台式电脑都消耗一定比例的能源。 云计算是过去几年里许多其它舒适的和愚蠢的概念的合乎逻辑的结论。所有这些概念都是旨在为这个机构的数据的组织带来一些条理性,如随需应变的信息、软件服务、虚拟化、Web服务、瘦客户机、SOA和Web 20。所有这些概念在某种程度上都能够由云计算管理。对于云计算的推广者来说,云计算可能是一种魔毯,让你坐在上面到达一个永远也无法企及的地方。在那里,客户机方面的所有问题都能够通过浏览器解决。 你的数据、你的应用程序和你的处理过程将保留在所有的地方,并且根据需要进行访问。这个事情能够在个人或者企业级别上实现。Google Mail、Google Docs和Facebook等应用都展示了这个功能是如何实现的。但是,所有常用的企业应用程序都可以通过这种相同的方式访问。网络已经从数据中心转移到了云计算。每一个用户的手头上都有一台潜在的超级计算机。 只要你能够访问网络并且有一台连接到网络的设备,你就不需要大型硬件。你能够在任何时间从任何地点访问你的数据。你的成本将下降。你只要支付你需要的东西的费用。你的数据保存在一个地方,是密封和安全的。你不必再负责它的安全。你的碳排放量和对于社区的影响将大幅度减少。你的数据、你的应用程序和你的服务器在你需要的时候都可以使用,没有基础设施或者资本开支的限制。云计算能够使用其它方法无法获得的计算能力。 云计算中的村谷歌和互联网已经显示了这种方法。全世界的数据都能够或多或少地不断地在网络上访问。网络已经成为虚拟实现的Marshall McLuhan所说的地球村。他在60年代写道:“后文艺时代的人的电子媒介将把世界变成一个村或者部落。在那里,每一件事情对于每一个人都是同时发生的。每一个人都知道发生的事情,因此将参与这个事情,每一件事情都在它发生的时刻发生。电视把事件同时传输到地球村。” McLuhan受到他所在的时代的限制。他的观察是提前的,但是,没有预测到数字计算机和互联网的兴起。但是,他把电子时代的世界看作是地球村的概念仍是对互联网已经变成的这个样子的一个有先见之明的预测。互联网已经变成了一个无以伦比的信息库 (准确的和不准确的信息都有,关于一切事情的和关于任何事情的信息),能够随意和随时访问,是你手头的百科全书。不过,如果我们访问的信息并不总是可以信赖的,它怎么能发展成这个样子 电子的地球村是谷歌为我们提供数据服务的更广泛的野心的更广泛的背景,是云计算还没有利用的潜力。当一个用户访问云计算中的数据时,他或者她需要一种合成的数据格式。这种数据经过处理可以回答具体的要求和优先选择,就像谷歌处理的互联网上的信息满足我们的查询请求一样。这将为合并、共享和发布存储在云中的信息提供许多机会。 不必说,现实与这个更大的目标还有一些差距。但是,在现实世界中还有一些实际的例子。银行已经建立了用于识别xyk的全球网络。在这个网络中,信息必须要共享,安全是有保证的。航空公司订票系统以同样的方式运行,用网络访问中央存储系统。大多数拥有广域网的任何规模的机构都能够在移动中访问信息。云计算把这种应用提高到了另一个水平。 作为一个概念证明,位于英国布里斯托市的惠普实验室早在2004年就发起了一个SE3D计划。这个计划允许12个小组的英国动画制作者自由访问惠普实验室的“Maya Rendering Service”(玛雅绘图服务),制作3D短片。参加者获得了Maya许可证和研讨会、公共会议和行业指导的时间表。这项服务提供在整个网络上的公用计算,这是把动画制作作为一项服务提供的原型。对于商业**公司来说,动画制作是需要很高成本的。 目前正在使用的最著名的云计算的例子是亚马逊的EC2网格。《纽约时报》最近租用了这个网格创建了数据容量达4TB的PDF文件库,包含了从1851年至1920年之间纽约时报发表的1100万篇文章。据《纽约时报》的Derek Gottfrid说,他使用了100个亚马逊的EC2实例和一个Hadoop应用程序在不到24个小时的时间里就编排完成了全部的1100万篇文章,并且生成了另外15TB数据,累计用了240美元,即使云计算没有作为一项主流的服务应用,它能提供这种难得的处理能力也是一种可行的选择。 一线希望同计算中的许多技术创新一样,云计算的应用遇到了传统的系统和设想的阻碍。尽管云计算能够提供节省成本的好处,但是,“新兴市场”的应用将超过在欧洲或者美洲的应用。 这有许多原因。在所谓的发达国家,大多数企业已经拥有依赖于传统的硬件、软件和常规的工作方式的基础设施。在东南亚、印度、中国或者撒哈拉以南的非洲,中小企业很少拥有复杂的客户机-服务器基础设施。政府和研究机构很希望鼓励应用价格便宜的技术。 IBM已经在中国、南非和越南等国家建立了云计算中心。那里的个人、团体和企业能够立即访问以前无法接触到的应用程序。 同云计算、网络计算和/或者公用计算的其它实例一样,这些中心以运行在大型计算机或者刀片式服务器上的虚拟化的Linux实例为基础,能够极大地促进这些中心所在地的本地的经济。 消除自己的困惑云计算的概念也许对于IT经理是有魅力的,但是,像许多颠覆当前做事方法的想法一样,云计算也存在一些阻力。 你不必因为个人和业务的理由把你的数据放在那里。你的个人信息、隐私和安全也许会脱离你的控制。你的个人台式电脑给予你控制权利。伴随者微软Windows *** 作系统软件、病毒漏洞、反垃圾邮件邮箱和“不公开即安全”等成长的用户几乎都不相信网络安全。由于所有这些原因,企业要拥有自己的数据,并且经常有充分的理由。 还有许多许可证和应用程序目前可用的问题,还有隐私和控制的问题。我们生活在一个这样一个世界里,数据的数量越搜集越多,而管理数据的人越来越少。谷歌也许不愿意共享你的数据,但是,政府机构能够超越法律访问他们要访问的东西。政府和企业正在日益为收集有关我们的信息所困扰。在这种环境下,谁愿意采用云计算这个事情不会发生,或者逻辑就是如此。“老大哥”正在云中注视着你呢。但是,这种假设的观点也许假设的集中化和控制程度都远远超过了实际的情况。 在当前的气候中应用云计算的最诱人的理由是它有可能大幅度减少能源消耗和浪费。耗费能源和浪费正是当前数据中心的特点。 云计算的价值在于它使我们回到了大型计算机的世界。这个区别是我们使用移动电脑或者掌上电脑放在我们手上的大型计算机比三十或者四十年前像一个仓库那样大的大型计算机的计算能力更强大。 企业接受云计算服务半年前,电子设备制造商Sanmina-SCI只有很少员工使用Google的云计算服务Google Apps,Google该服务中包括电子邮件、文档编辑及日程表等。而目前该公司使用Google Apps的员工已经超过1000人。 该公司首席信息官Manesh Patel表示:“我们的项目组位于全球各地,使用Google Apps能帮助他们有效的合作。”他预计,该公司未来三年Google Apps的用户数将增加至10000人,占员工总数的25%。 Sanmina和Google是最早在软件和计算方式上做出改变的公司。目前,亚马逊、Salesforce、IBM、甲骨文和微软都开始为企业用户提供网络存储和软件等服务,帮助它们进行客户关系管理。这种远程提供的计算服务被称作“云计算”。 云计算实际上包含多种技术,例如软件即服务(SaaS)和硬件即服务(HaaS)。软件即服务是Salesforce十年前提出的一种发布软件的新方式,而硬件即服务则是亚马逊和其他公司推出的通过网络提供存储和计算能力的新方式。 云计算市场将快速增长一些分析师认为,云计算代表了企业计算方式的改变。美林预计,未来5年中,云计算在全球的市场总额将超过950亿美元,全球软件市场的12%将转向云计算。 IBM、戴尔和惠普等相关厂商也已经开始转移自己的产品线,适应云计算服务的需求。IBM于8月1日宣布,将花费36亿美元新建一处云计算数据中心,这使得该公司全球数据中心数达到9处。戴尔则为许多云计算服务商和Web20企业提供设备,包括Facebook、微软、亚马逊和雅虎等。 鲍尔默近日的一份备忘录显示,微软也已将云计算列为09财年的五大工作重点之一。微软将允许客户在传统软件和软件服务之间进行选择。鲍尔默透露,微软下一代的Live服务和网络技术中将加入更多云计算功能。高盛一项调查显示,大约9%的IT经理表示,他们计划今年开始使用微软的软件服务。 可靠性和安全性问题不过,许多企业首席信息官仍对云计算的可靠性和安全性存有疑虑。7月20日,亚马逊S3服务断网6小时,这加剧了企业的担忧。咨询机构Gartner副总裁Daryl Plummer表示:“企业很难在短时间内大规模转向云计算。”他指出,企业高科技支出中的80%用户系统维护,而不是创新。 企业转向云计算的速度之慢也引起了业内的担忧。Google企业服务副总裁Dave Girouard表示:“这样下去市场将会枯竭。”他透露,目前有50万机构使用Google Apps,但是超过50%用户使用的是免费版。 企业正在探索能够使用云计算技术的新领域,例如人力资源管理等。Sanmina公司的Patel目前在考虑使用云计算来进行考勤和费用报告。他同时非常关注亚马逊提供的网络服务。他表示:“从企业角度来说,很明显我们只能逐渐起步。我们将首先在低优先级工作中测试云计算平台的能力。” 首席信息官担忧的另一个问题在于云计算是否符合法律规范,包括《萨班斯法案》和《美国健康保险条例》等。欧洲一家云计算服务提供商ITricity此前未能使自己的服务满足这些法律或规定。 寻求折中方案过去6个半月中,ITricity投入779万美元,将自己的服务升级至IBM的最新技术。IBM技术使ITricity的服务有更大的灵活性。ITricity表示,以往如果用户希望提升云计算能力,那么需等上一周时间。而IBM的新技术可以使这一时间缩短至1小时,甚至更短。 由于很多公司在现有设备上投资很大,因此许多人认为可以采用混合模式来引入云计算,即在公司内部,或称为“私有云”中完成一部分计算需要。 Google预计越来越多的企业将使用云计算。Google的目标是让更多人和公司适应Google Apps,并已经向一些大学免费提供Google Apps。

虚拟机是一种抽象化的计算机,通过在实际的计算机上仿真模拟各种计算机功能来实现的。

Java虚拟机有自己完善的硬体架构,如处理器、堆栈、寄存器等,还具有相应的指令系统。JVM屏蔽了与具体 *** 作系统平台相关的信息,使得Java程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行。

这种解释应该算是正确的,但是只描述了虚拟机的外部行为和功能,并没有针对内部原理做出说明。一般情况下我们不需要知道虚拟机的运行原理,只要专注写java代码就可以了,这也正是虚拟机之所以存在的原因--屏蔽底层 *** 作系统平台的不同并且减少基于原生语言开发的复杂性,使java这门语言能够跨各种平台(只要虚拟机厂商在特定平台上实现了虚拟机),并且简单易用。这些都是虚拟机的外部特性,但是从这些信息来解释虚拟机,未免太笼统了,无法让我们知道内部原理。

从进程的角度解释JVM

让我们尝试从 *** 作系统的层面来理解虚拟机。我们知道,虚拟机是运行在 *** 作系统之中的,那么什么东西才能在 *** 作系统中运行呢?当然是进程,因为进程是 *** 作系统中的执行单位。可以这样理解,当它在运行的时候,它就是一个 *** 作系统中的进程实例,当它没有在运行时(作为可执行文件存放于文件系统中),可以把它叫做程序。

对命令行比较熟悉的同学,都知道其实一个命令对应一个可执行的二进制文件,当敲下这个命令并且回车后,就会创建一个进程,加载对应的可执行文件到进程的地址空间中,并且执行其中的指令。下面对比C语言和Java语言的HelloWorld程序来说明问题。

首先编写C语言版的HelloWorld程序。

编译C语言版的HelloWorld程序:

gcc HelloWorldc -o HelloWorld

运行C语言版的HelloWorld程序:

zhangjg@linux:/deve/workspace/HelloWorld/src$ /HelloWorld

hello world

gcc编译器编译后的文件直接就是可被 *** 作系统识别的二进制可执行文件,当我们在命令行中敲下 /HelloWorld这条命令的时候, 直接创建一个进程, 并且将可执行文件加载到进程的地址空间中, 执行文件中的指令。

作为对比, 我们看一下Java版HelloWord程序的编译和执行形式。

首先编写源文件HelloWordjava :

编译Java版的HelloWorld程序:

运行Java版的HelloWorld程序:

zhangjg@linux:/deve/workspace/HelloJava/src$ java -classpath HelloWorld

HelloWorld

从上面的过程可以看到, 我们在运行Java版的HelloWorld程序的时候, 敲入的命令并不是 /HelloWorldclass 。 因为class文件并不是可以直接被 *** 作系统识别的二进制可执行文件 。 我们敲入的是java这个命令。 这个命令说明, 我们首先启动的是一个叫做java的程序, 这个java程序在运行起来之后就是一个JVM进程实例。

上面的命令执行流程是这样的:

java命令首先启动虚拟机进程,虚拟机进程成功启动后,读取参数“HelloWorld”,把他作为初始类加载到内存,对这个类进行初始化和动态链接(关于类的初始化和动态链接会在后面的博客中介绍),然后从这个类的main方法开始执行。也就是说我们的class文件不是直接被系统加载后直接在cpu上执行的,而是被一个叫做虚拟机的进程托管的。首先必须虚拟机进程启动就绪,然后由虚拟机中的类加载器加载必要的class文件,包括jdk中的基础类(如String和Object等),然后由虚拟机进程解释class字节码指令,把这些字节码指令翻译成本机cpu能够识别的指令,才能在cpu上运行。

从这个层面上来看,在执行一个所谓的java程序的时候,真真正正在执行的是一个叫做Java虚拟机的进程,而不是我们写的一个个的class文件。这个叫做虚拟机的进程处理一些底层的 *** 作,比如内存的分配和释放等等。我们编写的class文件只是虚拟机进程执行时需要的“原料”。这些“原料”在运行时被加载到虚拟机中,被虚拟机解释执行,以控制虚拟机实现我们java代码中所定义的一些相对高层的 *** 作,比如创建一个文件等,可以将class文件中的信息看做对虚拟机的控制信息,也就是一种虚拟指令。

编程语言也有自己的原理, 学习一门语言, 主要是把它的原理搞明白。 看似一个简单的HelloWorld程序, 也有很多深入的内容值得剖析。

JVM体系结构简介

为了展示虚拟机进程和class文件的关系,特意画了下面一张图:

根据上图表达的内容,我们编译之后的class文件是作为Java虚拟机的原料被输入到Java虚拟机的内部的,那么具体由谁来做这一部分工作呢?其实在Java虚拟机内部,有一个叫做类加载器的子系统,这个子系统用来在运行时根据需要加载类。注意上面一句话中的“根据需要”四个字。在Java虚拟机执行过程中,只有他需要一个类的时候,才会调用类加载器来加载这个类,并不会在开始运行时加载所有的类。就像一个人,只有饿的时候才去吃饭,而不是一次把一年的饭都吃到肚子里。一般来说,虚拟机加载类的时机,在第一次使用一个新的类的时候。本专栏后面的文章会具体讨论Java中的类加载器。

由虚拟机加载的类,被加载到Java虚拟机内存中之后,虚拟机会读取并执行它里面存在的字节码指令。虚拟机中执行字节码指令的部分叫做执行引擎。就像一个人,不是把饭吃下去就完事了,还要进行消化,执行引擎就相当于人的肠胃系统。在执行的过程中还会把各个class文件动态的连接起来。关于执行引擎的具体行为和动态链接相关的内容也会在本专栏后续的文章中进行讨论。

我们知道,Java虚拟机会进行自动内存管理。具体说来就是自动释放没有用的对象,而不需要程序员编写代码来释放分配的内存。这部分工作由垃圾收集子系统负责。

从上面的论述可以知道, 一个Java虚拟机实例在运行过程中有三个子系统来保障它的正常运行,分别是类加载器子系统, 执行引擎子系统和垃圾收集子系统。 如下图所示:

虚拟机的运行,必须加载class文件,并且执行class文件中的字节码指令。它做这么多事情,必须需要自己的空间。就像人吃下去的东西首先要放在胃中。虚拟机也需要空间来存放个中数据。首先,加载的字节码,需要一个单独的内存空间来存放;一个线程的执行,也需要内存空间来维护方法的调用关系,存放方法中的数据和中间计算结果;在执行的过程中,无法避免的要创建对象,创建的对象需要一个专门的内存空间来存放。关于虚拟机运行时数据区的内容,也会出现在本专栏后续的文章中。虚拟机的运行时内存区大概可以分成下图所示的几个部分。(这里只是大概划分,并没有划分的很精细)

总结

写到这里,基本上关于我对java虚拟机的理解就写完了。这篇文章的主题虽然是深入理解Java虚拟机,但是你可能感觉一点也不“深入”,也只是泛泛而谈。我也有这样的感觉。限于自己水平有限,也只能这样了,要是想深入理解java虚拟机,强烈建议读一下三本书:

《深入Java虚拟机》

《深入理解Java虚拟机JVM高级特性与最佳实践》

《Java虚拟机规范》

其实我也读过这几本书,但是它们对虚拟机的解释也是基于一个外部模型,而没有深入剖析虚拟机内部的实现原理。虚拟机是一个大而复杂的东西,实现虚拟机的人都是大牛级别的,如果不是参与过虚拟机的实现,应该很少有人能把它参透。本专栏后面的一些文章也参考了这三本书, 虽然讲解Java语法的书不计其数, 但是深入讲解虚拟机的书, 目前为止我就见过这三本,并且网上的资料也不是很多。

最后做一个总结:

1 虚拟机并不神秘,在 *** 作系统的角度看来,它只是一个普通进程。

2 这个叫做虚拟机的进程比较特殊,它能够加载我们编写的class文件。如果把JVM比作一个人,那么class文件就是我们吃的食物。

3 加载class文件的是一个叫做类加载器的子系统。就好比我们的嘴巴,把食物吃到肚子里。

4 虚拟机中的执行引擎用来执行class文件中的字节码指令。就好比我们的肠胃,对吃进去的食物进行消化。

5 虚拟机在执行过程中,要分配内存创建对象。当这些对象过时无用了,必须要自动清理这些无用的对象。清理对象回收内存的任务由垃圾收集器负责。就好比人吃进去的食物,在消化之后,必须把废物排出体外,腾出空间可以在下次饿的时候吃饭并消化食物。

扩展资料:

关于JAVA虚拟机的参数说明如下:

1、运行class文件

执行带main方法的class文件,Java虚拟机[3] 命令参数行为:

java <CLASS文件名>

注意:CLASS文件名不要带文件后缀class

例如:

java Test

如果执行的class文件是带包的,即在类文件中使用了:

package <;包名>

那应该在包的基路径下执行,Java虚拟机命令行参数:

java <;包名>CLASS文件名

例如:

PackageTestjava中,其包名为:comee2eetest,对应的语句为:

package comee2eetest;

PackageTestjava及编译后的class文件PackageTestclass的存放目录如下:

classes

|__com

|__ee2ee

|__test

|__PackageTestjava

|__PackageTestclass

要运行PackageTestclass,应在classes目录下执行:

java comee2eetestPackageTest

2、运行jar文件中的class

原理和运行class文件一样,只需加上参数-cp <jar文件名>;即可。

例如:执行testjar中的类comee2eetestPackageTest,命令行如下:

java -cp testjar comee2eetestPackageTest

3、显示JDK版本信息

当一台机器上有多个jdk版本时,需要知道当前使用的是那个版本的jdk,使用参数-version即可知道其版本,命令行为:

java -version

4、增加虚拟机可以使用的最大内存

Java虚拟机可使用的最大内存是有限制的,缺省值通常为64MB或128MB。

如果一个应用程序为了提高性能而把数据加载内存中而占用较大的内存,比如超过了默认的最大值128MB,需要加大java虚拟机可使用的最大内存,否则会出现Out of Memory的异常。启动java时,需要使用如下两个参数:

-Xms java虚拟机初始化时使用的内存大小

-Xmx java虚拟机可以使用的最大内存

以上两个命令行参数中设置的size,可以带单位,例如:256m表示256MB

举例说明:

java -Xms128m -Xmx256m

表示Java虚拟机初始化时使用的内存为128MB,可使用的最大内存为256MB。

对于tomcat,可以修改其脚本catalina sh(Unix平台)或catalinabat(Windows平台),设置变量JAVA_OPTS即可,例如:

JAVA_OPTS='-Xms128m -Xmx256m'

参考资料:

百度百科-java虚拟机

你好,我按你的要求写的代码如下,给足了注释

// 抽象父类

abstract class Father {

private int height;// 身高

private int weight;// 体重

public String getInterest() {// 获得兴趣

return "看书,书法";

}

}

// 子类

class Son extends Father {

private String nature;// 性格

public String getInterest() {// 改写父类获得兴趣方法

return "电脑,打球";

}

}

以上就是关于什么是SUN,有什么用全部的内容,包括:什么是SUN,有什么用、(急!!!)用DS1302与1602LCD设计的可调式电子日历与时钟 我要C程序啊。、什么是云技术等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9307533.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存