NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

Visual Studio 的 Ruby in Steel 提供 JRuby 支持

  • 2008-03-14
  • 本文字数:2817 字

    阅读完需:约 9 分钟

Ruby in Steel 是一个 Visual Studio 下的 Ruby IDE,它已经出现一段时间了,尽管还欠缺一些特性,比如快速Cylon Ruby 调试器。最近, Ruby in Steel for IronRuby 已经发布了 alpha 版本。现在,一个新的特性马上就要公布了:JRuby 调试器的支持,其中的重点是快速调试。(不要跟 Ruby in Steel JRuby支持弄混)。为了搞清楚JRuby 支持都包含些什么,以及为什么增加这些,在这个新特性发布前夕,我们访问了 Huw Collingbourne

InfoQ: VisualStudio 是如何支持 Java 的?你有没有增加一些支持,使得采用 JRuby 来开发跨语言的应用程序变得可能 / 容易(“跨语言”的意思是:使用 JRuby 代码来调用已有的 Java 库)?

Huw Collingbourne:VS 2005 的 Java 支持还可以,但不够好。本质上,Java 支持是通过微软的“Java dialect”来做到的,即 VS 2005 中的 J#。它具有语法着色和一些智能感知(IntelliSense)功能。但是在 VS 2008 中,微软移出了 J#,这意味你无法再获得 Java 支持了。即使你在 VS 2008 中打开 Java 代码,也只能使用普通文本编辑功能。要在 VS 2008 中生成一个用于 Java 的着色包组件并不难。我们能做到,但这不是我们想做的。支持一个调试器才更难。总而言之,我不推荐用 Visual Studio 来做正经的 Java 开发。还有很多更好的工具可供选择。

InfoQ: 跨语言调试:你能在调试时混合 Ruby 代码和 Java 代码吗?我的意思是,当你挂起一个调用 Java 方法的 Ruby 方法时,堆栈观察器能同时显示 JRuby 和 Java 的堆栈调用路径吗?

Huw Collingbourne:不行,这个调试器仅支持 Ruby。

InfoQ: 这是个内部开发吗(SapphireSteel 内部)?还是你基于已有的技术,比如 jruby-debug(基于跟踪的 JRuby 调试器,但为了加快运行,用 Java 写的,一个 ruby-debug)?

Huw Collingbourne:我们从头开始,混合使用几种语言写了这个编译器。它并不基于 jruby- debug。它的一部分是用 Java 写的,但通过 JNI 接口调用 C 来提高速度。慢的代码是用 Ruby 写的(比如处理用户输入),快的代码是用 Java 写 的,而更快的代码是用 C 和 X86 汇编语言写的。它使用 JRuby 的标准事件钩子方法来连接到 JRuby。JRuby 的一个有趣的地方是它的调试 / 跟踪系统 的兼容性很强。它与标准的 Matz Ruby(MRI)版本并不完全相同,但很相似,所以很容易上手。实际上,它比 MRI 的跟踪系统更易用,因为你无须为获得必需的接口而在解释器中做些乏味的事。另外,JRuby 的内部接口也很容易掌握和使用——即使基本上还没有文档。

InfoQ: 它有什么速度优势?还有没有更快的地方了? > Huw Collingbourne:目前为止,我们还没有用 benchmark 与 jruby-debug 进行对比测试。它在我们的机器上运行不起来,无论如何,它还是 beta 版(我们这样认为)。所以,用 benchmark 对比可能不公平。尽管如此,既然 jruby-debug 是把 C 语言写的 ruby-debug 直接移植到 Java 上去的,我们预期我们的实现也会和 jruby-debug 具有类似的速度优势(介于 50% 到 100%),因为它已经超越了 ruby-debug——并且由于使用 JNI 组件的原因,我们的实现可能还要更好一些。不过,我们能够用 benchmark 与我们自己的基于 C 的 MRI 调试器 (‘Cylon’) 进行比较。我们的 Java 版好像比 MRI Cylon 版慢 2 到 3 倍。这几乎完全是由于调用 JRuby 的跟踪函数和调用 MRI 中 C 的跟踪函数的速度有差别所致。比起 MRI,JRuby 本身通常会具有一样的速度——可能还会更快一点,但不要惊讶。我们认为 JRuby 胜出 MRI 的地方在于它很好得使用本地线程。这对服务器应用程序来说很重要。

InfoQ: 在 JRuby 1.1 中:调试器可以用于解释的、JIT 编译的,以及 AheadOfTime 编译的代码吗? > Huw Collingbourne:我们还没有发现 JRuby 1.1 的任何问题——它是标准的 Java(除了 JNI 代码以外)。但我们在试图优化它时发现一个有趣的地方:通过 C 或 C++ 优化所使用的技巧(也就是那些 令程序更快的方法)几乎不起作用。事实上,在某些情况下,这种优化在 Java 中适得其反。我们怀疑这可能是由 Java 的 HotSpot 优化器造成的。它好 象更喜欢你来做简单的事情,而让它来做优化。

InfoQ: 你有没有包含一些工具使得部署 JRuby on Rails 应用程序更容易些?

Huw Collingbourne:最近我们提供了一套通用的 Rails 集成开发工具——比如,各种保存和运行脚本的工具,可以让你摆脱命令行。但我们目前还没有开发专门针对 JRuby on Rails 应用程序部署的工具。

InfoQ: 它是免费版吗(就像 IronRuby,如果我没记错的话)?

Huw Collingbourne:这一次,我们的目标是只为我们的商业产品 Ruby In Steel 开发器提供 JRuby 支持。你说得没错,我们最近发布了一个 IronRuby IDE 的免费 alpha 版本(IronRuby 本身仍然处于 pre-alpha 状态),我们会在 IronRuby 的完成版发布后继续提供仅用于 IronRuby 的免费 IDE。目前我们没有计划发布仅用于 JRuby 的 IDE(老实说,我们甚至不知道人们对此 IDE 有没有足够的需求)。

InfoQ: JRuby 的特性有没有包括编辑功能?有没有计划支持 GUI 构建?

Huw Collingbourne:我们最近专注于 Ruby 的开发,没有计划扩展到对 Java 的支持。正如我刚才所说,已经有很多 优秀的 Java IDE 了。我们相信我们努力开发的成果远比做一个最好的 Ruby IDE 更有用。说到 GUI 支持,我们主要关注于提供编辑和调试工具。JRuby 可以利用所有现有的特性,包括智能感知和带有断点、步进、深入观察变量等功 能的快速调试器。
而最近,我们开始着手于对各种类型的可视化设计工具的支持。我们的一些客户已经使用了 beta 版的 Rails 可拖放设计环境(‘Visual Rails Workbench’),我们打算在三月底发布它。这个环境会很好地用于 JRuby,就像用于标准 Ruby 一样。有了它,你能够在屏幕上设计全页面的布 局,而不用去写 ERb(嵌入的 Ruby)模板代码了。我们还有一个可视化表单设计工具,内建在 IronRuby IDE 中。我们要不要专门做一个 JRuby 的可视化工具可能完全取决于人们对这个工具到底有多大的需求。

InfoQ: 你为什么敢冒 JRuby IDE 的市场风险?让 VisualStudio 开发者考虑使用 JRuby 有没有市场?

Huw Collingbourne:答案很简单,我们想要让用户在开发时有不止一种版本的 Ruby 可供选择。几 年前,只有一种 Ruby 解释器——即标准的 Matz Ruby 解释器。但我们对 JRuby 最近的发展印象深刻,并且我们感觉到 JRuby 非常重要,绝不能忽略。还有,我们一直想要让我们的用户不会感到他们被 “锁定”到一些特定的厂商的特定技术上。我们想给他们提供尽可能多的选择。最近我们认为 JRuby 就是 MRI 最好的替代者。另外,JRuby 还在积极的开 发中,谁知道一两年后它的地位会怎样?我们不想一直等着。这就是我们现在就决定支持 JRuby 的原因。

更新:Ruby in Steel 中的 JRuby 调试器支持还没有发布——一旦发布我们会尽快提供链接地址。

2008 年 3 月 7 日更新: JRuby 调试器宣布支持 Ruby in Steel

查看英文原文: JRuby support in Ruby in Steel for Visual Studio

2008-03-14 20:59925
用户头像

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

关注

评论

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

附PPT丨AWS基于数据湖构建云上的数据分析架构

dbaplus社群

数据湖 AWS

生产环境全链路压测建设历程 18:某快递 A 股上市公司的生产压测案例之中篇

数列科技杨德华

全链路压测 七日更

彩色的线,数据的诗,你好——贵州鲲鹏!

脑极体

Serverless 落地之痛怎么解?

阿里巴巴中间件

Serverless

手写线程池,对照学习ThreadPoolExecutor线程池实现原理!

小傅哥

Java 小傅哥 线程池 七日更 ThreadPoolExecutor

任务发布系统软件开发|任务发布APP开发

系统开发

用大白话给你解释Zookeeper的选举机制

爱笑的架构师

zookeeper ZooKeeper原理 七日更

如何成为架构师?

xcbeyond

个人成长 架构师 七日更

Nginx常见典型故障|Linux干货

赖猫

c++ nginx Linux

TypeScript | 第三章:函数、泛型和枚举

梁龙先森

typescript 编程 大前端 七日更

世界之书:《禅与摩托车维修艺术》与发现良质

lidaobing

禅与摩托车维修艺术 28天写作

Go中的Channel背后的设计哲学

soolaugust

Go Concurrency Patterns 七日更 CSP Go 语言

[git使用技巧] git提交忽略不必要的文件或文件夹

xcbeyond

git 七日更

业务中台建设 - 配置化

孝鹏

中台 微服务 配置化开发

代码零改动Serverless架构升级?这家在线编程教育企业是这么做的

阿里巴巴中间件

Python Serverless

《数据分析》PDF免费下载

计算机与AI

数据分析

Shell简介

入门小站

Shell

SQL优化最干货总结-MySQL「2020年终总结版」

Java架构师迁哥

“社恐”独处好去处:无人自习室,一个人的“世外桃源”

IoT云工坊

物联网 无人自习室 智能门禁 智能灯控 线上预约

12张图带你彻底理解分布式事务!!

冰河

分布式事务 BASE理论 TCC ACID CAP理论

夜莺二次开发指南-监控系统(1)

ning

滴滴夜莺 夜莺监控

JDK 16 即将发布,新特性速览!

xcbeyond

Java 七日更

语音助手中的复杂语义表达方法

DataFunTalk

AI nlp

Spring Cloud 2020.0.0正式发布,再见了Netflix

YourBatman

Spring Cloud Spring Boot netflix 2020.0.0

数据为墨,智能作笔:画一卷新姑苏繁华图

脑极体

wildfly 21的domain配置

程序那些事

程序那些事 wildfly wildfly21 配置管理 domain模式

单点破局思维|技术人应知的创新思维模型(8)

Alan

个人成长 技术人应知的创新思维模型 七日更 28天写作

夜莺二次开发指南-监控系统(2)

ning

滴滴夜莺 夜莺监控

30G 上亿数据的超大文件,如何快速导入生产环境?

楼下小黑哥

Java MySQL 并发编程 线程池

最有技术含量的面试

escray

面试 面经 七日更 十日谈

揭秘大流量场景下发布如丝般顺滑背后的原因

阿里巴巴中间件

阿里巴巴

Visual Studio的Ruby in Steel提供JRuby支持_Java_Werner Schuster_InfoQ精选文章