【AICon】探索八个行业创新案例,教你在教育、金融、医疗、法律等领域实践大模型技术! >>> 了解详情
写点什么

Android 的虚拟机 Dalvik 引来论战不断

  • 2007-11-19
  • 本文字数:1938 字

    阅读完需:约 6 分钟

随着上周Google 的Android SDK 的发布,关于它的API 以及在移动电话领域所带来的预期影响这些方面的讨论不胜枚举。不过,其中的一个话题在Java 社区是一石激起千层浪,这就是 Android 平台的基础—— Dalvik 虚拟机

Dalvik 和标准 Java 虚拟机(JVM)之间的首要差别之一,就是 Dalvik 基于寄存器,而 JVM 基于栈。一直以来都有人在猜测,选择基于寄存器的方式是因为它对提前优化(ahead-of-time optimization)提供了更好的支持,而这对类似于移动电话这样的受限环境是颇有裨益的。另一份针对基于寄存器虚拟机和基于栈虚拟机更深入的比较分析指出,基于寄存器的虚拟机对于更大的程序来说,在它们编译的时候,花费的时间更短。

Dalvik 和 Java 之间的另外一大区别就是运行环境——Dalvik 经过优化,允许在有限的内存中同时运行多个虚拟机的实例,并且每一个 Dalvik 应用作为一个独立的 Linux 进程执行。 Neil Bartlett 指出,给每一个应用赋予独立的进程可以允许动态安装、激活和去激活,但是他对Dalvik 为什么要选择这种方式而没有使用OSGi 在单一进程中实现表示疑问—— Radoslav Gerganov 回复说,独立的进程可以防止在虚拟机崩溃的时候所有程序都被关闭。Carl Rosenberger也指出 OSGi 也可以被移植到 Android 平台,而 Jilles van Gurp 对 Google 为何选择重新实现若干组件,如跨进程通信,表示疑问。

此外,Java 也已经不再是人们在Dalvik 上开发所选择的唯一语言了——已经有人在Dalvik 上运行Scala 取得了成功,并且 Hecl 也已经被成功移植了。另外更有人对运行Groovy 做了一次尝试,不过目前为止还不怎么成功。 Mono 项目的创始人 Miguel de Icaza 也对在 Dalvik 源码公开之后将 Mono 整合到 Dalvik 上表示了兴趣,而且也已经有人猜测如何用多种方式来实现整合了,包括与随Android SDK 提供的Java 到Dalvik 重编译器类似的CIL(Common Intermediate Language,通用中间语言)到Dalvik 重编译器。

Dalvik 的诞生也导致人们开始忧虑 Java 平台的第一次大规模的分道扬镳或许已经是进行时了——有人已经把 Davlik 和微软的JVM 以及 Sun 对微软的诉讼联系起来,等着看 Google 身上是否也会发生类似事情;另外一些人则指出, Google 并没有宣称 Dalvik 是一个 Java 实现,而微软却是这样做的。Sun 也对可能带来的阵营分裂表达了忧虑情绪,并提出和Google 合作来保证Dalvik 和JVM 之间的兼容性——Google 对此的解释是,Dalvik 是对解决目前Java ME 平台上分裂的一次尝试,也是为了提供一个拥有较少限制许可证的平台。甚至还有人怀疑这是否是 Sun 和 Google 两大阵营对 Java 之未来的一次大规模较量 Ian Skerret 认为,Dalvik 的诞生是对Sun 尝试控制和保护来自Java ME 收入来源的一次反应,以及对建立 OpenJDK 统辖理事会迟迟未果的回答。这也导致 Dalibor Topic 怀疑 Google 是否要重履 Sun 走过的路

当然,一个很有意思的问题是,为什么没人有勇气拿 Google 关于 OpenJDK 的问题反过来问 Google 呢? 虽然 Android 号称开源,但它仍是专有产品。Android 做过兼容性保证,是在秘密会议室中签署和保管的。Android 不具备任何治理模型,也没有证据指出将来会出现治理模型。Android 没有规范,并且它的许可证禁止任何替代实现的开发,因为这并非 Google 在 SDK 许可证中授权许可的使用权。Android 完全在 Google 的掌控之下,一旦有竞争性应用在财政上损害了 Google 的利益,Google 是保有一刀抹杀这些应用的权利的。从设计伊始,Android 就收到限制,只能在 Google 的财务利益允许的条件内开放。专有的 Java 也不是什么好货色,旧瓶装新酒而已。

这就好像我们在见证 JCP 的重生一样,人们排着队把开源社区的“街头信誉”在一个单一的、专有的实现的基础上借给另外一个封闭的厂商垄断集团。只不过这次的大头改姓 Google,而不是 Sun 了。

Stefano Mazzocchi 发布了一篇分析报告,深切入里地探讨了围绕Java ME 和Dalvik 的许可证问题,他得出结论说,Dalvik 的市场定位良好,足以给移动电话市场带来冲击。尽管Google 一直都很小心避免引起诉讼的几个关键点,但Mazzocchi 相信Sun 还是会起草知识产权案的状告书(IBM 也有可能)。他还指出,由于在JCP 之外操作,Google 可以非常快地对Android 进行更改,而且可以避开Sun 对任何JCP 更动的否决权——这样他们也可以为诸如USB 和蓝牙这样的组件加入接口,而这些组件在基础Java ME 实现中是不可用的。最后,通过在Apache 许可证下授权许可Dalvik 的源码,移动电话运营商更有可能采用Dalvik,因为运营商可以在不花费许可费用的情况下使用和修改它。

看起来Dalvik 已经在Java 社区中掀起了轩然大波——您持的又是什么样的想法呢?

查看英文原文: Dalvik, Android’s virtual machine, generates significant debate

2007-11-19 23:304491
用户头像

发布了 117 篇内容, 共 14.9 次阅读, 收获喜欢 0 次。

关注

评论

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

为什么中间件协议对区块链生态系统至关重要?

CECBC

为什么 StringBuilder 不是线程安全的?

xcbeyond

StringBuilder StringBuffer 6月日更

Taro3无埋点的探索与实践

GrowingIO技术专栏

taro AST sdk 无埋点 babel

🌏【架构师指南】分布式ID生成算法技术总结

洛神灬殇

分布式ID 6月日更

如果把四个消息队列都拉到一个群里,他们会聊些什么?

悟空聊架构

故事 消息队列 群聊 6月日更 悟空聊架构

Kubernetes手记(14)- 用户权限系统

雪雷

k8s 6月日更

校外培训行业迎来强监管,“教育+区块链”新模式试图解决行业痼疾

CECBC

致翻译界最可爱的许老

Qien Z.

翻译 6月日更

成为一个面霸需要面试多少回?

escray

极客时间 6月日更

运维大佬嘲笑我,这个你都不知道?

李阿柯

redis 面试 运维自动化

数据库事务与锁详解

阿骆麦迪

MySQL 事务 6月日更

【Vue2.x 源码学习】第十七篇 - 生成 render 函数 - 函数生成

Brave

源码 vue2 6月日更

Fuchsia OS vs Harmony OS 谁是下一个领跑

三掌柜

试用期 签约计划

并发王者课-铂金2:豁然开朗-“晦涩难懂”的ReadWriteLock竟如此妙不可言

MetaThoughts

Java 多线程 并发

前端 JavaScript 之『防抖』的简单代码实现

编程三昧

JavaScript 编程 大前端 防抖 函数节流

苹果iOS内购三步曲:App内退款、历史订单查询、绑定用户防掉单!--- WWDC21

37手游iOS技术运营团队

ios wwdc 苹果退款 appstore WWDC21

Low-Code能否威胁到专业的程序员?| 话题

三掌柜

试用期 签约计划 人气作者 TOP10

「SQL数据分析系列」6. 使用集合

数据与智能

sql 集合

JavaScript 学习(四)

空城机

JavaScript 大前端 6月日更

Java Selector模型

邱学喆

buffer selector SelectableChannel SelectionKey

SpringCloud Gateway 路由转发性能优化

中原银行

微服务 性能优化 SpringCloud Gateway 中原银行

数字人民币是央行数字货币还是法定数字货币?

CECBC

Flink State 和 Fault Tolerance(一)

Alex🐒

flink 翻译 flink1.13

网络攻防学习笔记 Day47

穿过生命散发芬芳

网络攻防 6月日更

优雅编程 | 7 个你应该掌握的 JavaScript 编码技巧

devpoint

JavaScrip 6月日更

C++友元的概念和使用的一些介绍

良知犹存

c++

“懂行”共识拓宽数字通道:川蜀大地与智能时代的“热辣”共振

脑极体

SpringCloud Gateway 动态路由

中原银行

微服务 SpringCloud Gateway 中原银行

【21-10】PowerShell 日期和时间

耳东@Erdong

PowerShell 6月日更

MySQL基础之十五:索引

打工人!

MySQL 6月日更

很多小伙伴问我推荐什么书籍和网课,这次把私藏很久的资料都贡献了(上)

C语言与CPP编程

Java c++ C语言 数据结构与算法 #python

Android的虚拟机Dalvik引来论战不断_Java_Ryan Slobojan_InfoQ精选文章