作者蔡学镛
广泛地说只要能执行 Java bytecode 者就可以称为 Java 平台(Java platform)大致上实现 Java 平台的方式有三种分别是 Java 虚拟机器(Java Virtual MachineJVM) Java 作业系统(Java Operating System) Java 晶片(Java Chip) 以下就此三种 Java 平台提出解说并比较之Java 虚拟机器所谓的 Java 虚拟机器指的是在作业系统上执行的一种程式此程式可以解读 Java bytecode并在作业系统的帮助下执行 Java bytecode这样的执行架构大致上可以分成四层分别是第一层(最上层)的 Java bytecode 第二层的 Java 虚拟机器 第三层的作业系统 第四层(最底层)的晶片 晶片执行上面的作业系统作业系统执行上面的 Java 虚拟机器Java 虚拟机器执行上面的 Java bytecode对于 Java bytecode 来说它只接触到 Java 虚拟机器所以当然「误以为」Java 虚拟机器就是它的平台实例Pentium III Chip + Windows OS + Sun HotSpot Client VM + Together/ Java ApplicationJava 作业系统如果把 Java 虚拟机器整合进既有的作业系统中(例如Mac OS X)或是打造一个全新的作业系统专门执行 Java bytecode(例如JOS)这类能直接执行 Java bytecode 的作业系统也可视为 Java 平台这样的执行架构大致上可以分成三层分别是第一层(最上层)的 Java bytecode 第二层的 Java 作业系统 第三层(最底层)的晶片 Java 晶片如果把 Java 作业系统和既有的晶片整合起来成为一组新的晶片(例如ARM arm )或者打造一个全新的 Java 专用晶片(例如aJile aJ)那么此一种类的晶片也是 Java 平台这样的执行架构大致上可以分成两层分别是第一层(最上层)的 Java bytecode 第二层(最底层)的 Java 晶片 三种方式的比较这三种都是 Java 平台各有优缺点很难说那一种方式比较好必须看你的需求而定透过虚拟机器来执行 Java 是最常见的架构方式一方面是因为虚拟机器的 Java 平台最容易被实作出来(相较于 Java 作业系统和 Java 晶片而言)二方面是因为只要有虚拟机器就可以让在不更动实体平台(作业系统和 CPU)的情况下多了执行 Java 程式的功能目前多数主流的实体平台(包括 WindowsLinuxMacSolarisPalmOSEPOC)都已经有 Java 虚拟机器了虚拟机器的架构因为分了太多层级所以效率上当然会比较差这是虚拟机器架构最为人所抨击的地方但是由于虚拟机器的技术一直在进步所以执行效率一直都有持续的提升目前已经相当逼近 Java 作业系统的架构方式所以虚拟机器的方式应该会继续成为 PC 上的 Java 平台主流一般来说透过 Java 作业系统来执行 Java bytecode效率会比虚拟机器的方式好所以 Java 虚拟机器被整合进作业系统中来提升该作业系统的附加价值这种作法有可能会成为一种趋势(例如 MacOS X 就把 Java 和作业系统作了很好的整合)但如果设计一套只能执行 Java 的全新作业系统可能不容易成功因为全新的作业系统势必面临驱动程式(device driver)不足的严重困扰因为此原因加上事实证明作业系统的 Java 平台比虚拟机器的 Java 平台效率提升不如预期多所以 IBM 和 Sun 合作的纯 Java 作业系统「JavaOS」计画已经停摆利用晶片的方式来实作 Java 平台对于 Java 程式的执行速度会有很大的提升毕竟硬体的速度比软体快许多这种方式以后会成为嵌入式系统的主流许多 Java 的 IA 产品(例如SetTop Box)都会开始使用 Java 晶片但是这种方式已经把 Java 整个变成硬体平台不适合再称为跨平台了