【3/18〜】Amazon、VMwareが語る『クラウドの未来』 スラッシュドット    はてなブックマーク  Yahoo!ブックマークに登録  印刷

OSS実装「Mono」で広がる.NETの応用

iPhoneでC#アプリが審査に通るワケ

2009/01/29

 iPhone向けにC#で書かれたゲームが40本以上存在する――。2009年1月7日付けのブログ投稿で、こんなにわかに信じられない現象を伝えるのは、メキシコ出身のオープンソース開発者、ミゲル・デ・イカザ(Miguel de Icaz)氏だ。iPhoneアプリケーションの開発といえば、アップルが提供するSDKに含まれるObjective-Cを使うか、Webブラウザ上でのみ動作するJavaScriptで実装するかのいずれかだった。

 C#のような実行時にランタイム(.NET Framework)を必要とするプログラミング言語は、iPhoneでは使えない。なぜなら、任意のコードを実行できるランタイムを配布パッケージに含めることを、セキュリティ上の理由からアップルが禁じているからだ。

 ではなぜ、C#アプリケーションが審査に通るのか? この背後には、オープンソースプロジェクト「Mono」(スペイン語でサルの意味)の存在がある。

なぜアップルの審査を通るのか

 イカザ氏が挙げる40本のゲームは正規のアプリケーションで、開発中のものを除いてすべてアップルの審査を通り、AppStoreで販売されている。jailbreakと呼ばれる非正規の手法を使うものではない。

mono01.png Blurstの「Raptor Coptor」はiPhone向けにC#で書かれたゲームの例だ

 これらのゲームはすべて、デンマークに本社を置くUnityテクノロジーズの「Unity/3D」という3Dグラフィック処理フレームワークを使っている。Unityは、そのベースにMonoを採用している。Monoは、マイクロソフトの.NET Frameworkと同等のものをオープンソースで実装したソフトウェアで、冒頭で紹介したイカザ氏が2001年に開始した同名のプロジェクトの成果物だ(イカザ氏はGNOMEプロジェクトの創始者としても知られている)。

 Unityでは、このMonoプロジェクトの成果物であるMono VMを使うことで、C#によるアプリケーション開発をサポートする。

 Mono/.NETでは、C#などの.NET向け言語で書かれたソースコードをCIL(Common Intermediate Language)と呼ばれる中間言語にコンパイルし、それがVM上で動く。実際にはVMは、CILを各プラットフォームで実行可能なオブジェクトコードにコンパイルする。Java同様、こうした2段構成を取ることで、.NETはソースコードのポータビリティを高めている。つまり、C#で書いたアプリケーションはマイクロソフトの.NET上でも、Mono上でも同じように動くわけだ。

 iPhoneの場合、問題はCILだ。CILから各プラットフォーム(IA-32のWindowsや、ARMのiPhone、PowerPCのWii)へのコンパイルは、実行時に動的に行われるため、これはアップルのSDKのライセンスに抵触する。このため、UnityではMonoをそのまま使うのではなく、JITコンパイラを省き、さらに、事前にすべてネイティブコードにコンパイルしてしまうAOT(Ahead-of-Time)コンパイルを行うことで問題を回避している。ただ、すべてネイティブコードにコンパイルされるとはいえ、ガベージコレクタや、スレッド処理などが必要なため、JITコンパイラをはじめ不要なコードを削ったMono VMを、静的にリンクする形となる。

 もともとiPhone向けのアプリケーションでは少しでもダウンロードサイズを小さくしたいというニーズがあるため、こうした機能限定版VMは、むしろ好都合だ。

 JIT省略版Monoを活用できるのはiPhoneプラットフォームばかりではない。イカザ氏によれば、XBox360でもJITコンパイラ搭載のMonoを含むようなソフトウェアは、ライセンス上、出荷できない。また、XBox360では書き換え可能なメモリページを実行用ページに変換できないというカーネルの制限があるため、いずれにしてもJIT利用は不可能だという。こうしたことから、JIT省略版Monoは活用できる可能性があるという。

Monoで進む.NETのクロスプラットフォーム対応と多様化

 言うまでもなく、.NETはJavaと似た技術だが、対応プラットフォームという点ではJavaにはるかに及ばなかった。.NET Frameworkの実装はマイクロソフトによるWindowsプラットフォーム向け(今後はAzure向けも)があるだけだった。それが現在、Monoプロジェクトの成果によって、対応プラットフォームを広げつつあるだようだ。MonoはLinuxを始めとするUnixやMac OS X、そしてWindowsプラットフォームで稼働する。さらに、すでに述べたようにMonoはiPhoneやXBox360でも動くほか、Androidで稼働したという報告もある。AndroidのMono上では、PythonやRubyの処理系(それぞれIronPython、IronRuby)まで動いているようだ。

mono02.png Monoプロジェクトのトップページ

 先述したUnityテクノロジーズは、Monoをベースに独自カスタマイズをすることで、iPhone向けのフレームワークだけでなく、WindowsやMac OS X、Wiiにも対応する製品を持っている。例えばアニメ専門チャンネルとして知られるカートゥーン・チャンネルは2009年1月14日、「FusionFall」と名付けられたMMO(Massively Multiplayer Online game:多人数参加型オンラインゲーム)の提供を開始したが、このゲームにはUnityのエンジンが使われており、ソフトウェアスタックとしてMonoが活用されているという。MonoのランタイムはMac OS X対応のためばかりではない。Windowsプラットフォーム向けにまでMonoを使っている。本家とも言えるマイクロソフトの.NET(およびそのバリエーションであるSilverlight)をさしおいて、Monoが使われているのには理由がある。それは、Monoがオープンソースで、用途に合わせて自由にカスタマイズやチューンができるからだという。JITを省いたVMを広く提供するというインセンティブは、マイクロソフトにはないだろう。

mono03.png カートゥーン・ネットワークが提供するWebブラウザベースの「FusionFall」はMonoをベースにして開発したという

 カスタマイズという点では、もっとおもしろい実験もある。Python開発者のイギリス人エンジニア、マイケル・フォード(Michael Foord)氏は、LinuxのFirefox上でPythonコードを走らせるという実験的試みを報告している。これまでにもすでにWindowsプラットフォーム向けではSilverlight 2に含まれるCoreCLRと呼ばれるランタイムにより、IronPythonをWebブラウザ内で使うことは可能だったが、MonoプロジェクトによるSilverlight実装でも、開発版のMoonlight 2を使えばLinuxやMac OS Xでも同等のことができることが示された形だ。

 Moonlightは2009年1月22日に、初めての正式版となるバージョン1.0が出たばかりだが、Linux上でバラク・オバマ氏の大統領就任演説ストリーミングの閲覧が可能だったことで話題となるなど、完成度を高めている(参考記事:LinuxでもSilverlightを見られる、「Moonlight 1.0」正式リリース)。Monoプロジェクトはマイクロソフトと提携関係にあるノベルのサポートを受けている(イカザ氏が創業した米Ximianを2003年にノベルが買収している)。このため、マルチメディア関連のコーデックなどでもMoonlightはマイクロソフトの協力を得られている。

広がるVM、広がる選択肢

 ゲームやグラフィクスという特殊用途ではあるにせよ、Mono VMが広がる兆しを見せていることは、Javaに遅れを取っていた.NETのマルチプラットフォーム化が、ようやく進み始めた姿だと見ることもできるだろう。MonoはGPLやLGPLのほかMITライセンスを選べるなど、使い勝手が良いというメリットもある。また、Javaのように大手エンタープライズベンダががっぷり組み合った結果、標準化や進化が遅くなるという足かせもない。そうした意味でも応用が広がりやすい段階にあると言えそうだ。

 .NET FrameworkもJava VMも、それぞれF#、IronPython、Scala、Clozure、JRuby、Fortressと、多様なプログラミング言語が花開くプラットフォームに進化しつつある。Monoが.NETの世界を広げることは、多様なプラットフォーム上でプログラミング言語の選択肢を広げることになる。これは.NET言語の開発者に限らず、同じスキルセット、ソースコードを流用できることにつながり、開発者としては歓迎すべきトレンドと言えそうだ。

(@IT 西村賢)

情報をお寄せください:

Insider.NET フォーラム 新着記事

@ITメールマガジン 新着情報やスタッフのコラムがメールで届きます(無料)

RSSフィード

アイティメディアの提供サービス

ホワイトペーパー(TechTargetジャパン/閲覧には会員登録が必要です)

スキルアップ/キャリアアップ(JOB@IT)

- PR -
- PR -

お勧め求人情報

キャリアアップ 〜JOB@IT
@IT Special -PR-
  TomcatやJBossなどAPサーバ環境に関する
情報を集約! “業務”用APサーバ大百科

New!
  一気に解説! 最新のクラスタストレージ
「RAIDを超えたストレージ基準」……など

New!
  クラウド的ユーザー体験の変化は脅威か?
仮想化技術を使いこなす運用管理術を紹介

New!

  上司や部下、部署内メンバーとの情報共有
を“ガラッ”と変えるコラボツールとは?

New!
  おばかアプリ選手権、第4弾開催中!!
ムダにカッコよくてくだらない作品求ム!

  社内ファイルサーバを“クラウド”に統合
VPN直結「クラウド型ストレージ」を紹介

  Twitterのアカウントはなぜ突破された?
メールによる新手の攻撃手法とその対策

  もう仮想化のお試しフェイズは終わりだ!
Hyper-V 2.0が基幹システムも仮想化

  美人!? まあまあ? 気になる いやし系!!
PV急増で「美人時計」がとった手段とは?

  クライアント企業から求められる人材
⇒IT技術と経営戦略を併せ持つ「戦略家」

  .NET編集長が実践する「技術情報検索術」
サンプル・コードを簡単に探す“技”は?

  業務効率と情報セキュリティ対策を両立!
手間なく確実に機密情報を守る方法とは?

  進化を続ける富士通ストレージETERNUS DX
製品開発者の自信を裏付けるものとは何か

  運用管理の課題を“2つの観点”から分析
ユーザー満足度の高い「仮想環境」とは?

  【CTC事例】約30の基幹システムを統合!
膨大なバッジジョブを制御した方法は?

  仮想化すればコストは削減できるか?
仮想化に必要な「3つの視点」を解説する

  その数、なんと400台以上! グループ内
サーバの「統合管理」によるメリットは?