【发布时间】:2010-09-18 19:33:12
【问题描述】:
我知道你可以在 Dalvik 的 VM 中运行几乎所有的 Java,而你可以在 Java 的 VM 中运行,但是限制不是很清楚。有没有人遇到任何主要的绊脚石?有什么大图书馆有问题吗?任何编译成 Java 字节码的语言(Scala、Jython 等)都不能按预期工作?
【问题讨论】:
我知道你可以在 Dalvik 的 VM 中运行几乎所有的 Java,而你可以在 Java 的 VM 中运行,但是限制不是很清楚。有没有人遇到任何主要的绊脚石?有什么大图书馆有问题吗?任何编译成 Java 字节码的语言(Scala、Jython 等)都不能按预期工作?
【问题讨论】:
Dalvik 不会处理或不会以与标准 Java 字节码完全相同的方式处理许多事情,尽管其中大多数都非常先进。
最严重的例子是运行时字节码生成和自定义类加载。假设您想创建一些字节码,然后使用类加载器为您加载它,如果该技巧在您的普通机器上有效,则保证在 Dalvik 上无效,除非您更改字节码生成。
这会阻止您使用某些依赖注入框架,最著名的例子是 Google Guice(尽管我相信有些人正在研究它)。另一方面,AspectJ 应该可以工作,因为它使用字节码检测作为编译步骤(尽管我不知道是否有人尝试过)。
至于其他 jvm 语言——任何最终编译为标准字节码并且在运行时不使用字节码检测的东西都可以转换为 Dalvik 并且应该可以工作。我知道人们确实在 Android 上运行了 Jython,而且运行良好。
需要注意的另一件事是没有及时编译。这不是严格意义上的 Dalvik 问题(如果你愿意,你可以随时编译任何字节码),但 Android 不支持,而且不太可能这样做。实际上,虽然标准 Java 的微基准测试毫无用处——组件在测试中的运行时特性与作为大型系统的一部分不同——但 Android 手机的微基准测试完全有意义。
【讨论】:
如果你看到“Dalvik Virtual Machine internals”Google IO session,你会发现 Dalvik 不支持generational GC。
因此,它可能会降低频繁创建和删除对象的性能。 Java VM 支持分代 GC,所以在同样的情况下它会表现出更好的 GC 性能。
此外,Dalvik 使用 trace-granuality JIT 代替方法粒度 JIT。
【讨论】:
我想可以在这里添加的另一件事是,Dalvik 在使用反射 API 列出类的字段时显然不保留字段顺序。现在,反射 API 无论如何都不会对它做出任何保证(所以理想情况下,无论如何你都不应该依赖它),但大多数其他虚拟机确实保留了顺序。
【讨论】:
只是为了添加到对话中,而不是为了恢复旧线程。我刚刚在搜索中遇到了这个问题,并想补充一点,Jython 也不能与 Dalvik 一起使用。简单地尝试做一个 hello world 示例将产生以下结果:
【讨论】: