RubyMotion 为开发者带来了使用 Ruby 编写 iOS 和 OS X 应用的一系列工具,它使用基于 LLVM 编译器进行代码编译,将 Ruby 编写的程序代码编译成本地原生代码。即将发布的 3.0 版本将支持Android 应用的开发。Android 的开发过程将类似于在iOS 平台上的开发:Rake 用来构建和运行应用,并生成清单文件和处理资源文件。
HipByte 为 Android 版本构建了一个全新的 Ruby 运行库。为了提高性能和实现与 Java 的互操作性,Ruby 的核心类(Fixnum、String、Array 等)都是同 Java 对应的。
统一的运行方式使得它与 Java API 能够很好的整合在一起,由于对象不必使用桥接方式进行整合,因此整体上具有良好的性能表现。运行库将通过调用 Java 本地接口实现与 Java 的整合。不仅如此,Ruby 版本的运行库本身就包含了 Android 的整套 API。
内存管理委派给了 Dalvik 的逐代回收和并发垃圾收集器。当需要创建和销毁全局引用时,运行库负责做这些事情,如一个实例变量是一个集合时,而局部变量的内存回收是在编译时确定的。
垃圾收集器是非常高效的,它在每个线程上都分配了对象分配池,实现了快速的对象分配。它会在指定的线程上运行终结方法,并能够妥善处理循环引用的问题。
我们很好奇,他们是如何实现 Ruby 运行库的垃圾回收器,如何以静态方式把 Ruby 代码编译成机器码,以及如何与 Android 运行库进行整合。所以我们对 HipByte 的创始人 Laurent Sansonetti 做了一次访谈。
InfoQ: 使用 RubyMotion 的时候,在不需要桥接的情况下就能够实现将 Ruby 的类直接映射到 Java 类,并且依然能够被编译成机器码,您能详细说明这一切是怎么发生的吗?
Android 的 Java 虚拟机有一套对应 C 语言的 API 叫做 JNI,它允许开发者使用 C 代码与 Java 虚拟机进行交互。在 Android 系统里,这就是 NDK 的一部分。
RubyMotion 是 Ruby 的静态编译版本。静态编译器能够将 Ruby 代码转换成机器码。在 Android 中,生成的机器代码能够调用 JNI API 实现与的 Java 交互(例如发送 Java 方法)。
整个处理过程和新的 Android 运行原理(简称 ART)是相似的。据我所知,唯一的不同之在于,RubyMotion 开发的应用程序被预编译成机器码,而在 ART 中,应用程序是在运行设备上进行编译的。
Ruby 的对象模型已经使用 Java 进行了重写,这就意味着 Ruby 的所有对象到 Java 对象的对应无需进行桥接、修改、转换,反之亦然。类似的,一些 Ruby 核心内建类是也是与 Java 一一对应的(如 Ruby 中的 Array 就是基于 java.util.ArrayList 的)。
InfoQ: 当您编译代码时,您是怎么处理 Ruby 元编程组件的?
事实上,RubyMotion 提供的 Ruby 的编译版本完全支持元编程。我们提供了一整套元编程 API,#eval 是唯一的一个例外,因为我们没有在应用中提供解释器(主要还是为了遵循苹果的政策)。
InfoQ: 您是使用 Dalvik 的垃圾回收器,但是垃圾回收器是怎么回收本地代码分配的内存呢?
由 Ruby 代码生成的本地代码是间接使用 Dalvik (或者 ART) 垃圾回收器进行垃圾回收的,因而所有的内存都是托管对象。对于一些特殊对象,运行库需要进行手动分配内存,并且在调用 finalize 时,进行这些对象的内存回收。
InfoQ: 我是否还能够继续使用我最喜欢的 RubyGems?
支持 Android 版本的 RubyMotion 具有一定的局限性,这和支持 iOS 与 OS X 版本的 RubyMotion 是一样的。这是因为 RubyMotion 是 Ruby 的一个静态编译版本,
#require
是被不支持的(在编译时必须提供所有文件),另外,#eval``也没有被实现(参见上文)。因此,常规的
RubyGems 不能正常使用。RubyMotion 有专门为自己设计的 gems, motion-toolbox.com 有一个由社区维护的精选的 RubyMotion 库列表。
InfoQ: 您现在能说下关于 RubyMotion 开发的应用程序性能的一些情况吗?当使用 JNI 时,应用程序有没有显著的性能降低?
我们还没有在性能方面投入过多精力,但是做了初步的测试,并且这些测试运行良好,也没有明显的性能下降 。调用 JNI 看上去也没有问题。事实上,它和很多 Android 运行库有一样的性能表现,并且都使用了相同的 API。
InfoQ: 谢谢您接受我的采访
支持 Android 版本的 RubyMotion 目前还未发布,但他们正在寻找感兴趣的beta 版本测试者。最终的版本将在今年晚些时候发布。
您是否有RubyMotion 实现的iOS 应用,且正打算迁移到Android 环境?您是一个想要使用Ruby 编写应用的Android 开发者吗(或许你已经是了)?你对使用RubyMotion 进行Android 应用开发有什么想法吗?
查看英文原文: RubyMotion Announces Android Support
感谢邵思华对本文的审校。
给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。
评论