マイクロソフト、次の.NET 7にネイティブコンパイラを搭載する見通しを明らかに
今回は「マイクロソフト、次の.NET 7にネイティブコンパイラを搭載する見通しを明らかに」についてご紹介します。
関連ワード (最初、登場、連携等) についても参考にしながら、ぜひ本記事について議論していってくださいね。
本記事は、Publickey様で掲載されている内容を参考にしておりますので、より詳しく内容を知りたい方は、ページ下の元記事リンクより参照ください。
マイクロソフトは現在開発中のフレームワーク「.NET 7」で、ソースコードからターゲットプラットフォームに対応したネイティブバイナリをコンパイル時に生成するAOT(Ahead of Time)コンパイラを搭載する見通しだと、「Announcing .NET 7 Preview 3」で明らかにしています。
AOTコンパイラ、すなわち事前コンパイラとは、アプリケーションのビルド時にソースコードをコンパイルしてネイティブバイナリを生成する機能を備えています。
一般に「コンパイラ」とはこのAOTコンパイラのことを指すことが多いですが、アプリケーション実行時にソースコードや中間コードから動的にネイティブバイナリを生成するコンパイラのことをJIT(Just-in-Time)コンパイラと呼ぶのに対比して、あえて「AOTコンパイラ」と呼ぶことも最近では増えてきました。
現在、.NET対応のプログラミング言語であるC#などのソースコードは、基本的にはコンパイル時に.NET専用の中間言語に変換され、実行時に.NETランタイムによって動的にネイティブバイナリが生成されることでターゲットマシン上で実行できるようになっています。
こうしたJITコンパイラや中間言語用仮想マシンの仕組みは、Javaなどを含む主要なプログラミング言語の多くで採用されているアプローチの1つとして、ソフトウェアのポータビリティと同時に高い性能や安定性などを実現してきました。
クラウドネイティブではネイティブバイナリのニーズが高まる
一方で、最近のクラウドネイティブ的なアプリケーションでは、サービスとして多数のソフトウェアを分散環境で実行し、相互に連携させつつ、負荷などに応じて頻繁にソフトウェアの起動と終了を繰り返す仕組みとなっています。
こうしたソフトウェア構成では、より効率的なコンピューティングリソースの利用を実現する上で、徹底的な高速起動と小さなランタイムが求められます。
そして、より小さなランタイムと高速な起動を実現するもっとも優れた方法として考えられるのが、あらかじめ生成されたネイティブバイナリを実行することです。
Javaも事前コンパイルによってネイティブバイナリを生成するソリューションが登場しつつありますし、コンパイラを標準的に採用するGoやRustといった言語への注目も高まってきています。
今回マイクロソフトが.NET 7で開発中のAOTコンパイラも、コンパイル時にネイティブバイナリを生成する機能を実現します。
最初はコンソール向けアプリとライブラリの開発がターゲット
.NETには以前からReadyToRunなどの仕組みのために事前コンパイルをする仕組みを一部に備えていましたが、今回開発中のAOTコンパイラはネイティブバイナリのみを生成する、いわゆる通常のコンパイラとして働きます。
ただし.NET 7で最初に搭載されるAOTコンパイラは、まずはGUIを持たないコンソール向けのアプリケーションとネイティブライブラリの開発がターゲットになると説明されています。
そしてAOTコンパイラは今後、.NETの数バージョンを経てさまざまなアプリケーションに対応する互換性を広げていくとのことです。下記は「Announcing .NET 7 Preview 3」からの引用です。
Looking ahead, Native AOT compatibility will be improved over the next few versions of .NET, however there will always be reasons to prefer JIT for many scenarios. We will also add first-class support in the dotnet SDK for publishing projects with Native AOT.
今後、Native AOTコンパイラの互換性は.NETの次の数バージョンで改善されていきますが、一方で多くのシナリオにおいてはJITが好ましい理由もあることでしょう。ネイティブAOTコンパイラを使用したプロジェクトの公開に向けて、.NET SDKにもファーストクラスのサポートを追加する予定です。
.NET 7の正式リリースは今年(2022年)の11月に予定されています。