写点什么

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

  • 2007-11-14
  • 本文字数:1772 字

    阅读完需:约 6 分钟

今天 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

2007-11-14 23:1410312
用户头像

发布了 88 篇内容, 共 273.4 次阅读, 收获喜欢 9 次。

关注

评论

发布
暂无评论
发现更多内容

基于KubeEdge的边缘节点分组管理设计与实现

华为云开发者联盟

云计算 云原生 后端

【Django | 开发】 (国际化项目&支持多语言)

计算机魔术师

8月月更

前端小白躺平摆烂可以吗

Liam

前端 前端开发 前端面试 Mock 前端入门

MobTech短信验证 Android端快速集成

MobTech袤博科技

android android-studio 短信验证

中大型现代服务行业的ERP,Telework现代服务中台

sofiya

【微信小程序开发】自定义tabBar案例(定制消息99+小红心)

计算机魔术师

8月月更

Python如何用类和对象来编程?

和牛

Python 8月月更

软件测试 | 测试开发 | 常见接口协议解析

测吧(北京)科技有限公司

TCP/IP

Java即时编译(JIT)原理与调优

柠檬汁Code(binbin0325)

JVM JIT 即时编译

长安链源码分析启动(7)

长安链

官宣!华为云GaussDB两大数据库通过中国信通院多项评测

科技怪咖

defi质押挖矿dapp系统开发智能合约部署详解

开发微hkkf5566

【小程序项目开发-- 京东商城】uni-app之商品列表页面 (下)

计算机魔术师

8月月更

华为云GaussDB(for Redis)全面对比Codis

科技云未来

字节跳动端智能工程链路 Pitaya 的架构设计

字节跳动终端技术

机器学习 客户端 端智能 Python. Pitaya

演讲实录|吴亚昆:云时代智能运维与可观测性探索

观测云

教育部“产学合作协同育人”项目华为云GaussDB项目入选名单公布

sofiya

数字藏品系统开发:NFT系统开发

开源直播系统源码

数字藏品 数字藏品软件开发 数字藏品源码出售 数字藏品开发

设计模式的艺术 第十六章责任链设计模式练习(提供一个假条审批模块:如果员工请假天数小于3天,主任审批该请假条;如果天数大于或等于3天,小于10天,经理审批;如果天数大于或等于10天,小于30天,总经理审批;如果超过30天,总经理不能审批,提示相应拒绝信息)

代廉洁

设计模式的艺术

软件测试 | 测试开发 | 接口测试 Mock 实战(二) | 结合 jq 完成批量化的手工 Mock

测吧(北京)科技有限公司

Mock

软件测试 | 测试开发 | 一文带你了解K8S容器编排(上)

测吧(北京)科技有限公司

k8s

[CSS入门到进阶] 4行CSS实现footer置底!超常见的需求,快来收藏

HullQin

CSS JavaScript html 前端 8月月更

在线XML转HTMLTable工具

入门小站

工具

快手能做好ToB吗?

ToB行业头条

tob 快手

如何为开源项目撰写 RFC

Databend

大数据 开源 #开源 databend

Databend SQL Planner 全新设计

Databend

sql 大数据 开源 #开源 databend

设计模式的艺术 第五章工厂方法设计模式练习(设计一个程序来读取各种不同类型的图片格式,针对每种格式都设计一个图片读取器)

代廉洁

设计模式的艺术

华为云发布《云原生2.0架构白皮书》,GaussDB技术再升级

sofiya

揭秘华为云GaussDB(for Redis)六大秒级能力盘点

科技云未来

创新技术领航者!华为云GaussDB获颁2022年云原生数据库领域权威奖项

科技云未来

在线图片隐写术解密解码传递数据

入门小站

工具

Google Android SDK舍弃Java ME,支持Java Lite和Apache Harmony_Java_Scott Delap_InfoQ精选文章