🎧 音声で聴く:ジョンとリラが本記事をもとに、現場視点と戦略視点から独自の見解をディスカッションしています。記事では詳細なデータと参照リンクをまとめています。
導入
JetBrainsが2026年2月19日、Visual Studio Code向けにJavaからKotlinへの変換拡張機能をリリースした。IntelliJ IDEA内部で使われてきた変換エンジンと大規模言語モデルを組み合わせた仕組みで、コンテキストメニューからワンクリックでJavaファイルをKotlinコードに変換できる。
Javaの代替言語として定着し、Androidアプリ開発を中心に広く使われてきたKotlin。その移行コストを下げるツールが、JetBrains製IDE以外のエディタに初めて正式に提供された形になる。ここが今回のニュースの核心だ。
背景と課題──なぜ今、Visual Studio Code向けなのか
KotlinはJetBrainsが開発した言語であり、同社のIntelliJ IDEA IDEが最も充実した開発環境であることに異論はない。JavaからKotlinへの変換機能もIntelliJ IDEAには長らく組み込まれていた。
一方で、多くの開発者が日常的に使うエディタはVisual Studio Codeだ。JetBrainsのKotlinプロダクトマネージャーであるAlina Dolgikh氏は、IntelliJ IDEAがKotlinにとって最高のIDEであることは変わらないとしつつ、「多くの開発者がさまざまなプロジェクトやタスクでVisual Studio Codeを使っている」ことを認め、それがこの拡張機能の開発動機だと説明している。
つまり今回の動きは、「Kotlinを使いたければJetBrains製IDEを買うべきだ」という囲い込み戦略から、「どの環境でもKotlinへの移行を容易にする」というエコシステム拡大戦略への明確なシフトと読める。
Javaで書かれたレガシーコードベースを抱える現場にとって、移行作業のハードルは技術的な難しさだけでなく、「普段使っている環境でそのまま作業できるか」という点にもある。IntelliJ IDEAのライセンスを全員分用意するのはコスト面で現実的でないケースも多い。Visual Studio Codeという無償かつ広く普及したエディタで変換が完結するなら、移行の敷居は確実に下がる。
技術・内容解説──変換エンジンの仕組みと設定項目
この拡張機能の技術的な特徴は、JetBrains IDEで使われている既存の変換エンジンと、大規模言語モデル(LLM)を組み合わせている点にある。JetBrainsによれば、Kotlinのイディオムや構文要件を尊重した変換が可能で、「ワンクリックで変換し、コミット前にレビューする」というワークフローをVisual Studio Code上で実現するとしている。
変換の対象は個別のJavaファイル単位だ。コンテキストメニューからアクションを実行するだけで、手動でのマイグレーション作業を大幅に削減できる。プロジェクト途中での言語切り替えにも対応する設計になっている。
拡張機能が提供する設定項目は以下の通り。
| 設定キー | 内容 | 既定値 |
|---|---|---|
| j2k.provider | 変換に使用するLLMバックエンド | GitHub Copilot |
| j2k.model | 選択したプロバイダーで使用するモデルタグ | codellama:instruct |
| j2k.ollama.baseUrl | プロバイダーにOllamaを選択した場合の接続先URL | ― |
| j2k.openRouter.baseUrl | プロバイダーにOpenRouterを選択した場合の接続先URL | ― |
| j2k.apiKey | 選択したプロバイダーのAPIキー(Visual Studio Codeのシークレットに保存) | ― |
注目すべきは、LLMバックエンドが差し替え可能な設計になっている点だ。既定値はGitHub Copilotだが、Ollamaを選べばローカル環境でLLMを動かせるし、OpenRouterを経由すれば複数のモデルを柔軟に選択できる。企業のセキュリティポリシーでクラウドにコードを送信できない場合でも、Ollamaによるローカル実行という選択肢がある。この柔軟性は実務上かなり重要だ。
個人的には、LLMの選択肢よりも「変換結果をコミット前にレビューできる」という設計のほうが影響が大きいと見ている。自動変換ツールの最大の問題は、生成結果を盲目的に受け入れてしまうことにある。レビューステップが明示的に組み込まれていることで、変換品質に対する開発者の責任が保たれる。
よくある誤解
誤解1:「IntelliJ IDEAの変換機能がそのままVisual Studio Codeに移植された」
変換エンジンの基盤は共通だが、LLMを組み合わせてイディオマティックな変換を提案する仕組みが加わっている。IntelliJ IDEAの変換機能の単純なポーティングではない。
誤解2:「プロジェクト全体を一括変換できる」
現時点で変換対象は個別のJavaファイル単位だ。プロジェクト全体の一括変換には対応していない。大規模なマイグレーションでは、ファイルごとに段階的に変換・レビューしていくワークフローが前提になる。
誤解3:「GitHub Copilotのサブスクリプションが必須」
既定値こそGitHub Copilotだが、OllamaやOpenRouterなど他のプロバイダーも選択できる。Ollamaであればローカル実行が可能なので、外部サービスへの課金なしでも利用できる可能性がある。ただし、モデルの性能差が変換品質に影響する点は留意が必要だ。
用語解説
- Kotlin
- JetBrainsが開発したJVM上で動作するプログラミング言語。Javaとの相互運用性を持ち、Androidアプリ開発の公式言語としてGoogleが採用している。
- LLM(大規模言語モデル)
- 大量のテキストデータで訓練された機械学習モデル。コード生成や自然言語処理に使われ、この拡張機能ではKotlinのイディオムに沿った変換提案に活用されている。
- Ollama
- LLMをローカル環境で実行するためのツール。クラウドにコードを送信せずにAI機能を利用でき、セキュリティ要件の厳しい環境で有用。
- OpenRouter
- 複数のLLMプロバイダーを統一的なAPIで利用できるルーティングサービス。モデルの切り替えが容易になる。
- イディオマティック変換
- 単なる構文の機械的な置き換えではなく、対象言語の慣用的な書き方(イディオム)に合わせた変換を行うこと。Kotlinの場合、データクラス、スコープ関数、null安全といった言語固有の特徴を活用したコードへの変換を指す。
インパクト・活用事例──現場での使いどころと留意点
この拡張機能が最も効果を発揮するのは、JavaからKotlinへの段階的な移行を進めているプロジェクトだろう。Kotlinの特徴のひとつは、Javaとの混在が可能な点にある。既存のJavaコードベースを一度に全て書き換える必要はなく、ファイル単位で少しずつKotlinに変換していくアプローチが取れる。
特にAndroidアプリ開発の文脈では、GoogleがKotlinを公式言語として採用して以降、新規コードはKotlinで書きつつ既存のJavaコードが残っている状態のプロジェクトが多い。こうした混在プロジェクトで、レガシーなJavaファイルを順次Kotlinに変換する作業に活用できる可能性がある。
正直なところ、JetBrainsがVisual Studio Code向けにこの種のツールを出すこと自体が、Kotlinのエコシステム戦略における重要な転換点だ。これまでJetBrainsは自社IDEの優位性を維持するためにKotlinの先進的な機能をIntelliJ IDEAに集中させてきた。競合エディタに変換ツールを提供するのは、IntelliJ IDEAのライセンス収入よりもKotlin自体の普及を優先する判断と見ることができる。
ただし、懸念もある。LLMを介した変換は、モデルの性能に依存する部分が大きい。既定値のcodellama:instructと、GitHub Copilotの最新モデルでは変換品質に差が出る可能性がある。また、LLMが生成するコードの正確性は保証されない。Alina Dolgikh氏は「Kotlinのイディオムと構文要件を尊重した信頼できる変換」が期待できると述べているが、複雑なジェネリクスやリフレクションを多用するJavaコードでどこまで品質が保たれるかは、実際に使い込んでみないとわからない。
日本の開発現場、特にSIer系のプロジェクトでは、Javaで構築された大規模な業務システムが数多く稼働している。Kotlinへの移行は技術的には可能でも、「動いているものに手を加えるリスク」を嫌う文化が根強い。この拡張機能のように、ファイル単位で変換してレビューできるツールは、段階的な移行を進める上での心理的なハードルを下げる効果が期待できる。ただし、変換後のコードレビュー体制が整っていなければ、LLM由来の微妙なバグが混入するリスクは残る。
アクションガイド
この拡張機能を実際に試す場合と、導入を検討する場合のアクションを、経験レベル別に整理した。
Kotlin経験者・移行プロジェクト担当者向け
- Visual Studio Marketplaceから拡張機能をインストールする
- j2k.providerの設定を確認し、プロジェクトのセキュリティ要件に合ったLLMバックエンドを選択する
- まずは小規模なユーティリティクラスなど、依存関係が少ないJavaファイルで変換を試す
- 変換結果を必ずレビューし、Kotlinのイディオムに沿っているか、型の扱いに問題がないか確認する
- セキュリティ上コードの外部送信が不可な場合、Ollamaによるローカル実行を検討する
Javaメインの開発者・Kotlin初学者向け
- まずKotlinの基本構文(null安全、データクラス、拡張関数など)を学んでから変換ツールを使う
- 変換ツールの出力をそのまま使うのではなく、「Javaのこの書き方がKotlinではどうなるか」を学ぶ教材として活用する
- 変換結果とKotlin公式ドキュメントを照らし合わせて、イディオマティックな書き方を身につける
保存用チェックリスト
- □ Visual Studio Marketplaceから拡張機能をインストール済みか
- □ j2k.providerの設定を確認したか(GitHub Copilot / Ollama / OpenRouter)
- □ セキュリティポリシーに照らして適切なLLMバックエンドを選択したか
- □ APIキーが必要な場合、j2k.apiKeyに設定済みか
- □ 変換対象のJavaファイルがコンパイル可能な状態か
- □ 変換後のKotlinコードをレビューする体制があるか
- □ 変換後にユニットテストを実行して動作を確認する手順が決まっているか
- □ Ollamaを使う場合、ローカルにモデルがインストール済みか
未来展望とリスク
JetBrainsがVisual Studio Codeというサードパーティのエディタ向けにKotlin関連ツールを積極的に提供し始めたことは、Kotlinの普及戦略の変化を示唆している。IntelliJ IDEAの優位性を維持しつつ、Kotlinそのもののユーザーベースを広げる二正面作戦だ。
現時点では個別ファイル単位の変換に限られるが、今後プロジェクト全体の一括変換やマルチモジュール対応が進む可能性はある。ただし、LLMを利用した変換である以上、モデルの更新によって変換品質が変動するリスクは常に存在する。バージョンアップで変換結果が変わり、以前は通っていたテストが失敗するといった事態も想定しておくべきだ。
また、これは地味だが重要な変化だと思う。JetBrainsが自社IDE以外のエディタにKotlinの移行ツールを提供することで、「Kotlin=JetBrains製IDEでしか快適に使えない言語」というイメージが薄れていく。それがKotlinの採用判断にどう影響するかは、今後の普及率に表れるだろう。
まとめ
JetBrainsが2026年2月19日にリリースしたVisual Studio Code向けJavaからKotlin変換拡張機能は、同社IDE内部の変換エンジンとLLMを組み合わせ、コンテキストメニューからのワンクリック変換とコミット前レビューを実現するものだ。LLMバックエンドはGitHub Copilot、Ollama、OpenRouterから選択でき、ローカル実行にも対応する。
個別ファイル単位の変換という制約はあるが、JavaからKotlinへの段階的な移行を進める現場にとっては実用的なツールになり得る。変換品質はLLMモデルに依存するため、レビュー体制の確保が不可欠だ。JetBrainsがVisual Studio Codeという競合エディタ向けにこの種のツールを提供した事実そのものが、Kotlinの普及戦略における転換を象徴している。
参照リンク・情報源
- JetBrains introduces Java to Kotlin converter for Visual Studio Code(InfoWorld)
- Java to Kotlin conversion comes to Visual Studio Code(JetBrains公式ブログ)
- Java to Kotlin Converter拡張機能(Visual Studio Marketplace)
本記事は情報提供を目的としています。最新情報は必ず公式サイトでご確認ください。
AIの最新トレンドを毎日短くまとめてXで配信しています。
記事では書ききれない速報や所感も流しているので、気になる方はフォローしてみてください。
🎧 Podcast
AIの最新トレンドを音声で毎日配信中です。
