InfoQ

InfoQ

News

マイブックマーク

ブックマークするためにログイン または 会員登録 する

ブックマークされました!

ブックマークがエラーになりました。もう一度お願いします。

JRuby総まとめ:JRuby 1.3 リリース、ruby2java、JSR 292の進展

作者 Werner Schuster , 翻訳者 南 伸二 投稿日 2009年6月14日

セクション
デベロップメント,
設計/アーキテクチャ
トピック
コンパイラ ,
JRuby ,
パフォーマンス&スケーラビリティ ,
Ruby ,
ランタイム ,
Java
タグ
JRuby ,
仮想マシン ,
JVM

原文(投稿日:2009/6/9)へのリンク

JRuby 1.3が現在利用可能になっており、多くのパフォーマンスの改善とバグフィックスがもたらされた。新しい改善は、Nailgunが含まれるようになったこと、より高速なタイムアウト、などである。(NailgunやJava1.4のサポートの終了など、1.3における変更に関するより詳細な情報はこちら).

JRuby 1.3は、Google AppEngineのJavaサポート上で動作する初めての安定版リリースでもある。

新しいバージョンのtimeoutには問題が残っているようである。その問題はJRubyのtrunk版では修正されている。今はJRubyをtrunkからビルドする手間が必要であるが、1.3.1リリースはこの修正を加えた形で利用可能になると思われる。

同時に、JRubyの速度の改善に関する作業が続いている。コンパイルされたJRubyを改善するプロジェクトの一つがruby2javaである。

Ruby2Javaコンパイラはクラスの「実行時」定義を調べて通常のJavaクラスを生成します。すべてのメタプログラムされたメソッドは、メソッドに対する実行時変形と同様に、Javaクラスに反映されます。

ruby2javaプロジェクトはKenaiにホストされている。Ruby2javaを実行するには最低でもJRuby 1.3が必要である。

ruby2javaは、現在すでにあるJVM上でJRubyの速度を改善することを目的としている。しかし、JDK/Java 7におけるいくつかの新しい変更によって、著しい効率の改善が見られるかもしれない。JSR-292は、この目的を達成するためのJVMに対する変更のうち、最初のいくつかを集めたものである。
変更の一つは新しいバイトコードinvokedynamicの導入であり、これによってメソッド呼び出しに関するカスタムルックアップメソッドを提供することが出来るようになる。すなわち、あるメッセージがレシーバに送られたときに、言語ランタイムを呼び出して、そのルックアップを利用して実際に実行するメソッドを返却する、というようなことが可能になる。これ自体は大きな改善をもたらすわけではないかもしれないが、JVMがこういったタイプのメソッド呼び出しに関するよりよい最適化をもたらし得ると考えられる。
このアプローチは何年もの間議論され続けてきたが、ゆっくりと現実のものになろうとしている。JavaOne'09においていくつか講演がJSR-292に関するものであった。新生VMに向かって (リンクはスライドのオンライン版)とJSR 292クックブック (リンクはスライドのオンライン版)である。これら2つの講演では、その変更に関して深く議論されているし、JVMに対して将来行われるであろう変更に関するアイデアも提供している。

Charles Nutter氏はまた、JRubyでinvokedynamicと新しいメソッドハンドルを利用することを進めていて、初期バージョンのコードがJRubyブランチで利用可能である
新しいフィーチャーはJVMのリサーチ版かまたは初期のJDK 7ビルドでのみ利用可能である(invokedynamicは数週間前JDK 7ツリーに含まれるようになった)。

特集コンテンツ一覧

GAE開発の落とし穴

Googleのクラウド環境をつかったGoogle App Engineによる開発するにあたり、初めての試みで苦悩する開発者達の経験をもとに、各開発フェーズにあわせて問題点やどう解決したかをご紹介します

イベントレポート:「Coqチュートリアル#1」

去る1月12日、定理証明支援系ツールCoqの初心者向けチュートリアルが開催さ れた(http://kokucheese.com/event/index/23667/)。今後も2月2日 (http://kokucheese.com/event/index/23744/)、2月9日、2月16日と引き続き開 催されていく予定である。本記事では、開催の様子をレポートする。

Javaの未来についてのNeal Gafter氏とのディスカッション

Choosing Options

Neal Gafter氏はOracleによるJava買収の影響に関する議論、Javaにセグメンテッドスタックやメタオブジェクトプロトコルを追加することについての主張、そしてJavaとC#との比較について話をしてくれた。

Google Dartのエッセンス:アプリケーションの構築、スナップショット、Isolate

GoogleはVMをともなう新しい言語であり、JSコンパイラでもあるDartをプレビューした。 InfoQはDartのアプリの構築に貢献する文法の裏側を探った:スナップショット、Isolate、モジュール方式

CSPベースのモデル検査ツール「Process Analysis Toolkit」

本記事ではCSPベースの「マルチドメイン・モデル検査ツール」である、PAT(Process Analysis Toolkit)について紹介する。モデル検査は、形式手法(Formal Method)という方法論を基礎とする技術であり、複雑さが増大しながらも安全性を求められる、現在のソフトウェア開発の状況に対する処方箋の1つとして注目されている手法である。

Jenkinsによる継続的インテグレーションのススメ(4) ~CloudBeesでJenkinsをサービスとして使う~

前回まで、Jenkinsの幾つかの側面に注目して解説をしてきました。シリーズ最後の今回は、Jenkinsをサービスとして使う方法を紹介します。

書籍『抽象によるソフトウェア設計-Alloyではじめる形式手法-』の紹介

Alloyは、MITにて開発された仕様記述言語であり、ツールによる自動解析を使い、インクリメンタルに形式仕様が書けることが特長である。筆者らはAlloy開発者による、Alloyを使った形式手法入門書を翻訳、今夏にオーム社より刊行した。本記事では、Alloyの簡単な概要と、翻訳書『抽象によるソフトウェア設計』(「Alloy本」)を紹介する。

Windows デバイスで開発するタッチユーザーインターフェイス

スマートフォンを中心としたマルチデバイスにおけるタッチユーザーインターフェイスへの対応は、既に必須の項目となりつつある。本記事では、Windows デバイスにおける UX のベースとなっている「メトロ」というデザイン言語を掘り下げながら、既存環境を意識しつつもどのようにタッチユーザーインターフェイス開発に取り組んでいくべきであるかについて解説していく。