InfoQ

新闻

Google Android SDK舍弃Java ME,支持Java Lite和Apache Harmony

作者 Scott Delap 译者 张龙 发布于 2007年11月14日 下午11时14分

社区
Java
主题
移动
标签
Java ME
今天Google发布了Android SDK。 它是在Open Handset Alliance(开放手机联盟)宣布后不久发布的。Sun公司CEO Jonathan Schwartz高度称赞了OHA以及它对Java的支持。然而,直到今天我们仍旧不是很了解Android中关于Java的一些细节。

Android使用Linux2.6作为硬件抽象层的基础,该底层系统提供了驱动支持、内存管理和网络支持等功能。在该抽象层之上是一套用C/C++编写的本地库,该库提供了如下一些特性:OpenGL、字体、多媒体编解码器、SQL Lite和用于浏览器渲染的Web工具集。其中比较有趣的地方就来自于该抽象层的上一层和Dalvik虚拟机。

Google没有提供一个Java SE或Java ME的完整版本,而是另行其道。首先,Google提供了一套Java核心包的有限子集。该子集包含了平时使用比较多的包,例如:java.nio、java.lang和java.util。除了Android的类库外,还使用了一些开源项目,其中包含Apache的HttpClient。然而,JME类和传统意义上的Java UI包(Swing和AWT)并没有出现。实际上这种方式正是Google在另一个项目GWT所采取的模式,GWT使用Java作为开发语言,但是并不是说JDK的所有特性它都支持。

Android使用了一个定制的虚拟机来运行应用程序,这些应用程序是用它所支持的Java语言子集来编写的:

每个Android应用都运行在它自己的进程里面,使用它自己的Dalvik虚拟机实例。Dalvik被设计成为可以在一个设备中有效运行多个虚拟机。Dalvik虚拟机执行Dalvik格式(.dex)的文件,该格式对于有限内存的情况做了优化。该虚拟机是基于寄存器的,并且运行由Java编译器(已经被内嵌的“dx”工具转换为.dex格式)编译成class文件。Dalvik虚拟机依赖于Linux内核来完成一些底层的功能,例如:线程和底层的内存管理。

Dalvik已经对在有限的电池和CPU的情况下移动设备的运行做了优化。Apache V.P.,JCP的Geir Magnusson 指出Dalvik使用了Apache的Harmony类库。Android SDK采用的是Apache软件许可。Ars Technica详细比较了该许可和GPLv2许可之间的差别。

上面的图片展示了Android栈示意图。蓝色部分是用Android的Java子集来编写的。这包含了应用框架服务,例如资源管理和窗口。Android Phone的核心部分、Browser和Contacts应用也是使用Java来编写的,并且运行在Dalvik虚拟机下。

Android SDK 目前支持Windows XP及之后的版本、OS X10.4.8+和Linux,同时需要JDK5或6。虽然Eclipse并不是必须的,仍有一个Eclipse3.2+的插件随着调试工具和模拟工具一起被提供。

先前一些开发者对该SDK的评论是好坏参半。一些人认为不应该使用Java lite:

……我认为这是令人失望的。没有与任何一个Java组织结盟是一个让人感到可惜的设计抉择。在我看来,Android与现存的所有东西都是不兼容的,然而这种设计毫无必要。除此之外,Android重复了很多Java、J2ME和很多开源项目的现有功能。我相信每种情况Android都会有自己的考虑,但是结果却是重复发明轮子。总的来说,我怀疑与现存的东西相比,Android的APIs是否更快、更灵活、更易用……

Ryan Block从更一般的角度提出了对Java的质疑:

Android采用Java作为应用层环境,对此感到失望的肯定不止我一个人。……Android已经拥有了比一般支持Java设备更优化的框架,一个移动多任务的Java虚拟机应用环境肯定不如操作系统的本地代码运行效率高。这一点已经可以在演示视频里面看到了,视频中一些挥动、轻点、轻触的手势比起iPhone / iPod Touch要笨拙得多,视觉上也没那么炫……

其他人比如Ed Burnette认为Android这样做是对的:

……对于开发者来说这确实是一个好消息,因为我们不必再为了不同的架构去重新编译程序,例如编译一个ARM版本,再去编译一个x86版本。这对于厂商来说也是一个好消息,因为他们在手机硬件设备的使用上拥有了更大的灵活性。他们可以采用新的处理器而不用担心影响现有的应用。……
查看英文原文:Google's Android SDK Bypasses Java ME in Favor of Java Lite and Apache Harmony

译者简介:张龙,同济大学软件工程硕士,现就职于理光软件研究所。主要从事文档工作流和办公自动化解决方案的研发工作。热衷于Java轻量级框架的研究,对敏捷方法很感兴趣。曾有若干年的J2EE培训讲师经历。参与InfoQ中文站内容建设,请邮件至china-editorial@infoq.com
Java UI是个问题 发表人 cao yunfei 发表于 2007年11月16日 上午2时6分
Re: Java UI是个问题 发表人 Xiaogang Guo 发表于 2007年11月17日 下午12时32分
Re: Java UI是个问题 发表人 sw pollux 发表于 2007年11月19日 下午9时54分
Re: Java UI是个问题 发表人 hailong zhang 发表于 2007年11月24日 上午8时39分
Re: Java UI是个问题 发表人 thomas tong 发表于 2008年1月11日 下午7时31分
java社区的分歧视乎越来越多了 发表人 Da Lei 发表于 2007年11月16日 下午10时46分
Re: java社区的分歧视乎越来越多了 发表人 Xiaogang Guo 发表于 2007年11月17日 下午12时17分
  1. 返回顶部

    Java UI是个问题

    2007年11月16日 上午2时6分 发表人 cao yunfei

    AWT太笨重了,Swing不够酷,SWT即酷又方便,可惜好像目前用的不多。Google Android SDK的UI部分用的是什么呢?

  2. 返回顶部

    java社区的分歧视乎越来越多了

    2007年11月16日 下午10时46分 发表人 Da Lei

    我是一个.net使用者,但是我一直关注着java社区。 总的感觉是java社区里各自为政的问题好突出,先是ibm,现在是google,自己的虚拟机,自己的UI,似乎都不买sun的帐,ibm在java的应用上取得了巨大的成功,google是否也想复制这种模式呢?

  3. 返回顶部

    Re: java社区的分歧视乎越来越多了

    2007年11月17日 下午12时17分 发表人 Xiaogang Guo

    也可以说是好事。Sun在某些方面固步自封,另一方面JCP扯皮又太多,IBM和Google财大气粗自然不鸟它。分歧也不见得是坏事,如果都跟着Sun的屁股转,大家恐怕还在受着EJB的煎熬呢。 不过Android这个还真是“伪”Java。另外Mono也说有兴趣实现一个CIL-to-Dalvik recompiler。

  4. 返回顶部

    Re: Java UI是个问题

    2007年11月17日 下午12时32分 发表人 Xiaogang Guo

    从SDK来看,应该是他们自己实现的一套东西。

  5. 返回顶部

    Re: Java UI是个问题

    2007年11月19日 下午9时54分 发表人 sw pollux

    看看他们的UI继承就清楚了,View继承于java.lang.object,另外onjava上有一篇好的文章,可以去看看,http://www.oreillynet.com/onjava/blog/2007/11/android_first_impressions.html?CMP=OTC-FP2116136014&ATT=Android+First+Impressions 另外,thethirdpart打算加入android的adc行列,如果有愿意和我们一起来分这分羹的朋友,请和我们取得联系。www.thethirdpart.com/blog

  6. 返回顶部

    Re: Java UI是个问题

    2007年11月24日 上午8时39分 发表人 hailong zhang

    我倒是觉得Swing在Windows是运行得挺不错的,正确配置下,感觉不到跟Windows程序有什么差别,不知道是不是新版的库有所改进!

  7. 返回顶部

    Re: Java UI是个问题

    2008年1月11日 下午7时31分 发表人 thomas tong

    相信google将有很好的发展,让我一起学习进步,欢迎访问http://www.loveandroid.com

深度内容

和Google互补的搜索引擎Wolfram|Alpha

Wolfram|Alpha与Google究竟是什么关系,Wolfram|Alpha自己是如何定位的?Wolfram|Alaph在多大程度上是语义网搜索呢?InfoQ中文站就等等这些问题采访了Wolfram研究公司中国区商务经理王翔。

SOA契约成熟度模型

本文说明了所推荐的契约版本管理设计策略是如何与SOA成熟度模型发生联系的。文章目的是为实现版本管理和可组合性提供一个路线图。

数据服务简介

Vijay Narayanan在这篇文章中对数据服务的几个方面进行了介绍,它们都是SOA实践者和数据架构师感兴趣的内容。本文对数据服务的几个方面进行了介绍,包括需求定义,基本原理和好处、范围、开发以及消费模式。

分块云计算

在本文中,Jimmy Nilsson描述了一种他在过去数年间观察到的一种正在缓慢成长的架构风格,他把这种风格称为“分块云计算”。

豆瓣网技术架构变迁

罗马不是一天建成的,豆瓣的技术架构也是随着用户规模的增长一直在持续变化中。在本次演讲中,豆瓣的首席架构师洪强宁将与大家一起分享从上线时的单台服务器架构开始一直到现在的豆瓣架构变迁历程。

融合思想:深入探索S#arp架构

Billy McCafferty展示了S#arp架构,它在ASP.NET MVC框架的基础上,荟萃了当今的最佳实践,应用在ASP.NET Web应用程序的架构设计中。

王雷谈开源以及新兴市场计划

中国作为新兴市场中的新兴市场,是Sun在美国之外实施SSE(SUN Startup Essentials)项目重点关注的地区。在QCon Beijing 2009期间,InfoQ中文站有幸对此项目的负责人王雷先生进行了采访,探讨了关于开源、新兴市场、SSE等话题。

使用HTML5构建下一代的Web Form

HTML5 是由 WHATWG发起的,最开始的名称叫做Web Application 1.0,而后这个标准吸纳了Web Forms 2.0的标准,并一同被W3C组织所采用,合并成为下一代的HTML5标准。