`
zhaohaolin
  • 浏览: 1017669 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

java编译原理【转】

    博客分类:
  • JAVA
阅读更多

Java编译原理: 
Java 虚拟机(JVM)是可运行Java 代码的假想计算机。只要根据JVM规格描述将解释器移植到特定的计算机上,就能保证经过编译的任何Java代码能够在该系统上运行。本文首先简要介绍从Java文件的编译到最终执行的过程,随后对JVM规格描述作一说明。 
   
  一.Java源文件的编译、下载 、解释和执行 
  Java应用程序的开发周期包括编译、下载 、解释和执行几个部分。Java编译程序将Java源程序翻译为JVM可执行代码?字节码。这一编译过程同C/C++ 的编译有些不同。当C编译器编译生成一个对象的代码时,该代码是为在某一特定硬件平台运行而产生的。因此,在编译过程中,编译程序通过查表将所有对符号的引用转换为特定的内存偏移量,以保证程序运行。Java编译器却不将对变量和方法的引用编译为数值引用,也不确定程序执行过程中的内存布局,而是将这些符号引用信息保留在字节码中,由解释器在运行过程中创立内存布局,然后再通过查表来确定一个方法所在的地址。这样就有效的保证了Java的可移植性和安全 性。 
   
  运行JVM字节码的工作是由解释器来完成的。解释执行过程分三部进行:代码的装入、代码的校验和代码的执行。装入代码的工作由"类装载器"(class loader)完成。类装载器负责装入运行一个程序需要的所有代码,这也包括程序代码中的类所继承的类和被其调用的类。当类装载器装入一个类时,该类被放在自己的名字空间中。除了通过符号引用自己名字空间以外的类,类之间没有其他办法可以影响其他类。在本台计算机上的所有类都在同一地址空间内,而所有从外部引进的类,都有一个自己独立的名字空间。这使得本地类通过共享相同的名字空间获得较高的运行效率,同时又保证它们与从外部引进的类不会相互影响。当装入了运行程序需要的所有类后,解释器便可确定整个可执行程序的内存布局。解释器为符号引用同特定的地址空间建立对应关系及查询表。通过在这一阶段确定代码的内存布局,Java很好地解决了由超类改变而使子类崩溃的问题,同时也防止了代码对地址的非法访问。 
   
  随后,被装入的代码由字节码校验器进行检查。校验器可发现操作数栈溢出,非法数据类型转化等多种错误。通过校验后,代码便开始执行了。 
   
  Java字节码的执行有两种方式: 
  1.即时编译方式:解释器先将字节码编译成机器码,然后再执行该机器码。 
  2.解释执行方式:解释器通过每次解释并执行一小段代码来完成Java字节码程 序的所有操作。 
  通常采用的是第二种方法。由于JVM规格描述具有足够的灵活性,这使得将字节码翻译为机器代码的工作 
   
  具有较高的效率。对于那些对运行速度要求较高的应用程序,解释器可将Java字节码即时编译为机器码,从而很好地保证了Java代码的可移植性和高性能。 
   
  二.JVM规格描述 
  JVM的设计目标是提供一个基于抽象规格描述的计算机模型,为解释程序开发人员提很好的灵活性,同时也确保Java代码可在符合该规范的任何系统上运行。JVM对其实现的某些方面给出了具体的定义,特别是对Java可执行代码,即字节码(Bytecode)的格式给出了明确的规格。这一规格包括操作码和操作数的语法和数值、标识符的数值表示方式、以及Java类文件中的Java对象、常量缓冲池在JVM的存储 映象。这些定义为JVM解释器开发人员提供了所需的信息和开发环境。Java的设计者希望给开发人员以随心所欲使用Java的自由。 
   
  JVM定义了控制Java代码解释执行和具体实现的五种规格,它们是: 
  JVM指令系统 
  JVM寄存器 
  JVM栈结构 
  JVM碎片回收堆 
  JVM存储区 
   
  2.1JVM指令系统 
   
  JVM指令系统同其他计算机的指令系统极其相似。Java指令也是由 操作码和操作数两部分组成。操作码为8位二进制数,操作数进紧随在操作码的后面,其长度根据需要而不同。操作码用于指定一条指令操作的性质(在这里我们采用汇编符号的形式进行说明),如iload表示从存储器中装入一个整数,anewarray表示为一个新数组分配空间,iand表示两个整数的"与",ret用于流程控制,表示从对某一方法的调用中返回。当长度大于8位时,操作数被分为两个以上字节存放。JVM采用了"big endian"的编码方式来处理这种情况,即高位bits存放在低字节中。这同 Motorola及其他的RISC CPU采用的编码方式是一致的,而与Intel采用的"little endian "的编码方式即低位bits存放在低位字节的方法不同。 
   
  Java指令系统是以Java语言的实现为目的设计的,其中包含了用于调用方法和监视多先程系统的指令。Java的8位操作码的长度使得JVM最多有256种指令,目前已使用了160多种操作码。 
   
  2.2JVM寄存器 
   
  所有的CPU均包含用于保存系统状态和处理器所需信息的寄存器组。如果虚拟机定义较多的寄存器,便可以从中得到更多的信息而不必对栈或内存进行访问,这有利于提高运行速度。然而,如果虚拟机中的寄存器比实际CPU的寄存器多,在实现虚拟机时就会占用处理器大量的时间来用常规存储器模拟寄存器,这反而会降低虚拟机的效率。针对这种情况,JVM只设置了4个最为常用的寄存器。它们是: 
  pc程序计数器 
  optop操作数栈顶指针 
  frame当前执行环境指针 
  vars指向当前执行环境中第一个局部变量的指针 
  所有寄存器均为32位。pc用于记录程序的执行。optop,frame和vars用于记录指向Java栈区的指针。 
   
  2.3JVM栈结构 
   
  作为基于栈结构的计算机,Java栈是JVM存储信息的主要方法。当JVM得到一个Java字节码应用程序后,便为该代码中一个类的每一个方法创建一个栈框架,以保存该方法的状态信息。每个栈框架包括以下三类信息: 
  局部变量 
  执行环境 
  操作数栈 
   
  局部变量用于存储一个类的方法中所用到的局部变量。vars寄存器指向该变量表中的第一个局部变量。 
  执行环境用于保存解释器对Java字节码进行解释过程中所需的信息。它们是:上次调用的方法、局部变量指针和操作数栈的栈顶和栈底指针。执行环境是一个执行一个方法的控制中心。例如:如果解释器要执行iadd(整数加法),首先要从frame寄存器中找到当前执行环境,而后便从执行环境中找到操作数栈,从栈顶弹出两个整数进行加法运算,最后将结果压入栈顶。 
  操作数栈用于存储运算所需操作数及运算的结果。 
   
  2.4JVM碎片回收堆 
   
  Java类的实例所需的存储空间是在堆上分配的。解释器具体承担为类实例分配空间的工作。解释器在为一个实例分配完存储空间后,便开始记录对该实例所占用的内存区域的使用。一旦对象使用完毕,便将其回收到堆中。 
  在Java语言中,除了new语句外没有其他方法为一对象申请和释放内存。对内存进行释放和回收的工作是由Java运行系统承担的。这允许Java运行系统的设计者自己决定碎片回收的方法。在SUN公司开发的Java解释器和Hot Java环境中,碎片回收用后台线程的方式来执行。这不但为运行系统提供了良好的性能,而且使程序设计人员摆脱了自己控制内存使用的风险。 
   
  2.5JVM存储区 
   
  JVM有两类存储区:常量缓冲池和方法区。常量缓冲池用于存储类名称、方法和字段名称以及串常量。方法区则用于存储Java方法的字节码。对于这两种存储区域具体实现方式在JVM规格中没有明确规定。这使得Java应用程序的存储布局必须在运行过程中确定,依赖于具体平台的实现方式。 
   
  JVM是为Java字节码定义的一种独立于具体平台的规格描述,是Java平台独立性的基础。目前的JVM还存在一些限制和不足,有待于进一步的完善,但无论如何,JVM的思想是成功的。 
   
  对比分析:如果把Java原程序想象成我们的C++ 原程序,Java原程序编译后生成的字节码就相当于C++原程序编译后的80x86的机器码(二进制程序文件),JVM虚拟机相当于80x86计算机系统,Java解释器相当于80x86CPU。在80x86CPU上运行的是机器码,在Java解释器上运行的是Java字节码。 
   
  Java解释器相当于运行Java字节码的“CPU”,但该“CPU”不是通过硬件实现的,而是用软件实现的。Java解释器实际上就是特定的平台下的一个应用程序。只要实现了特定平台下的解释器程序,Java字节码就能通过解释器程序在该平台下运行,这是Java跨平台的根本。当前,并不是在所有的平台下都有相应Java解释器程序,这也是Java并不能在所有的平台下都能运行的原因,它只能在已实现了Java解释器程序的平台下运行。 


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/oyto12o/archive/2010/01/31/5274967.aspx

分享到:
评论

相关推荐

    编译原理实验词法分析器 java语言版

    总的来说,这个实验提供了一个学习编译原理和Java语言的实践平台。通过完善词法分析器以支持带符号的常数,学生可以深入理解编译器的工作原理,增强处理文本解析和模式匹配问题的能力。对于Java开发者来说,这样的...

    java现代编译原理.rar_java 编译_现代编译原理_编译_编译原理_编译原理 java

    Java现代编译原理是计算机科学中的一个重要领域,它涉及到如何将高级编程语言,如Java,转换为机器可执行的指令。这个主题对于深入理解Java程序的生命周期和性能优化至关重要。以下是对这一领域的详细阐述: 首先,...

    编译原理java编译器

    本实验主要围绕“编译原理”展开,重点关注Java编译器的设计与实现,涵盖词法分析、语法分析、语义分析以及中间代码生成等关键步骤。 首先,我们来深入了解一下词法分析。词法分析是编译过程的第一步,它的任务是将...

    编译原理课程解释器构造Java源码

    在这个“编译原理课程解释器构造Java源码”中,我们可以推测这是一个基于Java编程语言实现的解释器项目。Java是一种广泛应用的面向对象的编程语言,它的跨平台特性使得它成为构建各种软件工具的理想选择,包括解释器...

    现代编译原理(虎书,包含c版和java版中英文,源码,全书答案)

    现代编译原理(虎书,包含c版和java版中英文,源码,全书答案) 1. 现代编译原理C语言描述_虎书 从官方网站下载的全书代码 现代编译原理课后题答案 Advanced.Compiler.Design.and.Implementation(Steven.S....

    编译原理.rar编译原理编译原理

    编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理编译原理...

    编译原理java版

    《编译原理java版》是基于经典教材《现代编译原理》(通常被称为“虎书”)的Java语言实现版本。这本书深入浅出地讲解了编译器设计的基本概念、技术和方法,对于学习和理解编译器的工作原理,以及如何用Java语言实现...

    \编译原理\编译原理课程讲义\java图.

    本文将深入探讨Java编译原理,并通过一张简化的流程图来帮助理解Java代码如何从编写到最终执行的全过程。 #### 二、编译时间环境 Java程序的编译过程主要发生在开发者的计算机上。在这个阶段,开发者编写的源代码...

    编译原理编辑器java

    这个过程通常分为多个阶段,包括词法分析、语法分析和语义分析,这些步骤在“编译原理编辑器java”中扮演着关键角色。 **词法分析**是编译过程的第一步,也称为扫描或标记。它负责识别源代码中的基本单元,即词法...

    编译原理PL0源码(java版)

    编译原理是计算机科学中的一个重要领域,它研究如何将高级编程语言转换为机器可以理解的低级指令。PL0是一种非常简单的编程语言,通常被用作编译原理教学中的示例,因为它具有清晰的语法结构,易于分析和生成。在这...

    编译原理 词法分析 语法分析 Java版【NFA DFA DFA最小化】[有注释版可下,请参看楼主其他分享]

    在编程和计算机科学领域,编译原理是理解计算机语言如何转化为机器可执行代码的基础。它主要涉及三个核心步骤:词法分析、语法分析和语义分析。本资源着重于词法分析和语法分析,特别是非确定性有限自动机(NFA)和...

    用Java做编译原理正规式转换成NFA.rar

    本资源“用Java做编译原理正规式转换成NFA.rar”主要关注的是编译原理中的一个重要概念——正规式到非确定性有限自动机(NFA)的转换。下面我们将深入探讨这个主题。 正规式是描述有限语言的数学表达式,常用于定义...

    编译原理课程设计 编译器 java编写

    比上次传的编译原理增加了一个由输入的文法判断句子是否正确(合乎这个文法的语法规则),根据出入栈进行分析判断匹配 完整版:并含说明文件、文档 和相应的材料 包含 :词法分析 语法分析 是上次传的两个编译原理...

    编译原理实验java

    本实验“编译原理实验java”旨在通过实际操作加深对这一理论的理解,主要涵盖词法分析、语法分析以及中间代码生成这三个核心步骤。我们将使用Java编程语言来实现这些功能,并采取递归下降的解析方法。 1. **词法...

    SLR编译原理java代码

    在本资源中,提供的是用Java语言实现SLR编译原理的代码,这对于学习编译器设计和理解SLR解析技术具有极大的帮助。 SLR解析器的工作原理基于一套称为SLR分析表的表格,这个表包含了词法规则、状态以及动作。当解析器...

    java程序编译原理实验

    java程序编译原理实验

    现代编译原理java版

    《现代编译原理Java版》是一本深入探讨编译器设计和实现的权威著作,尤其以其在Java语言环境下的解析和应用而闻名。编译原理是计算机科学领域的重要分支,它涉及将高级编程语言转化为机器可执行代码的过程,对软件...

    现代编译原理-Java语言描述

    2、Modern.Compiler.Implementation.in.Java.Second.Edition.chm Last year you may have seen the Modern Compiler Implementation in C: Basic Techniques (1997) which was the preliminary edition of our new ...

    编译原理,词法分析,java

    在编程领域,编译原理是理解计算机语言处理过程的关键部分,它涉及词法分析、语法分析、语义分析以及代码生成等多个步骤。本资源主要关注的是词法分析,这一阶段的任务是从源代码文本中识别出一个个有意义的符号,即...

Global site tag (gtag.js) - Google Analytics