Java Platform Module System (JPMS) は、Java プラットフォームの創設以来、最も重要なアーキテクチャ上の変更の 1 つです。 Java アプリケーションを幅広く扱ってきた私は、この強力な機能がコードの構造と編成の方法をどのように変えたかをこの目で見てきました。
Java 9 で導入されたモジュール システムは、パッケージよりも高いレベルでコードを編成する基本的な方法を提供します。モジュールの核心は、その依存関係と他のモジュールで利用できるものを明示的に宣言する自己完結型のユニットです[1]。これは、すべてのコードが他のすべてのコードに基本的にアクセス可能であった従来のクラスパス ベースのアプローチからの革命的な変更でした。
基本的なモジュール宣言から始めましょう:
module com.myapp.core { requires java.base; exports com.myapp.core.api; provides com.myapp.core.spi.Service with com.myapp.core.impl.ServiceImpl; }
この単純な宣言には、モジュールの命名、依存関係の宣言、パッケージのエクスポートなど、いくつかの重要な概念がカプセル化されています[2]。モジュール システムはコンパイル時と実行時にこれらの境界を強制し、以前よりも強力なカプセル化を提供します。
モジュール式アプリケーションを作成する場合、通常、構造は次のようになります。
myapp/ ├── src/ │ ├── module-info.java │ └── com/ │ └── myapp/ │ └── Main.java └── out/
シンプルなモジュール型アプリケーションの完全な例を次に示します。
// module-info.java module com.myapp { requires java.logging; exports com.myapp.api; } // com/myapp/api/Service.java package com.myapp.api; public interface Service { String getMessage(); } // com/myapp/internal/ServiceImpl.java package com.myapp.internal; import com.myapp.api.Service; public class ServiceImpl implements Service { public String getMessage() { return "Hello from modular service!"; } }
JPMS の最も強力な機能の 1 つは、その強力なカプセル化メカニズムです[4]。従来のパブリック/プライベート アクセス修飾子とは異なり、モジュール レベルのカプセル化により、内部実装の詳細がパブリックとしてマークされている場合でもアクセスできなくなります。
次のシナリオについて考えてみましょう:
module com.myapp.core { exports com.myapp.core.api; // Internal packages are not exported // com.myapp.core.internal remains hidden }
内部パッケージ内のクラスがパブリックであっても、明示的にエクスポートされない限り、モジュールの外部からアクセスすることはできません[1]。これは、モジュール以前の Java と比較してカプセル化が大幅に向上していることを示しています。
JPMS は、required ディレクティブを通じて明示的な依存関係宣言を導入します。これは、Java アプリケーションをしばしば悩ませていた「JAR 地獄」問題を防ぐのに役立ちます[3]。依存関係が通常どのように管理されるかは次のとおりです:
module com.myapp.service { requires com.myapp.core; requires java.sql; requires transitive com.myapp.common; }
requires 推移的ディレクティブは、依存関係の転送を可能にし、これに依存するすべてのモジュールで必要なモジュールを利用できるようにするため、特に興味深いものです[2]。
モジュール システムは Java の ServiceLoader メカニズムと美しく統合されています。
module com.myapp.core { uses com.myapp.spi.Plugin; } module com.myapp.plugin { provides com.myapp.spi.Plugin with com.myapp.plugin.impl.PluginImpl; }
これにより、サービス インターフェイスと実装が明確に分離され、真のプラグイン アーキテクチャが可能になります[8]。
既存のアプリケーションを JPMS に移行するのは困難な場合があります。最も一般的な問題は次のとおりです:
module com.myapp.core { requires java.base; exports com.myapp.core.api; provides com.myapp.core.spi.Service with com.myapp.core.impl.ServiceImpl; }
移行を支援するために、Java では --add-exports および --add-opens コマンドライン オプションが提供されています[5]:
myapp/ ├── src/ │ ├── module-info.java │ └── com/ │ └── myapp/ │ └── Main.java └── out/
モジュール システムにより、以下を通じてランタイムの最適化が向上します。
jlink を使用してカスタム ランタイム イメージを作成できます。
// module-info.java module com.myapp { requires java.logging; exports com.myapp.api; } // com/myapp/api/Service.java package com.myapp.api; public interface Service { String getMessage(); } // com/myapp/internal/ServiceImpl.java package com.myapp.internal; import com.myapp.api.Service; public class ServiceImpl implements Service { public String getMessage() { return "Hello from modular service!"; } }
テストには特別な配慮が必要です。典型的なテスト モジュールのセットアップは次のとおりです:
module com.myapp.core { exports com.myapp.core.api; // Internal packages are not exported // com.myapp.core.internal remains hidden }
多くのビルド ツールは、モジュール型アプリケーションのテストに特化したサポートを提供します。たとえば、Maven は、適切な設定で maven-surefire-plugin を使用します[8]。
モジュール式アプリケーションのより完全な例を見てみましょう:
module com.myapp.service { requires com.myapp.core; requires java.sql; requires transitive com.myapp.common; }
この構造は、強力なカプセル化と明示的な依存関係を維持しながら、懸念事項を明確に分離します[11]。
モジュール システムは、Java アプリケーションの構造に関する考え方を根本的に変えました。移行は、特に既存のアプリケーションにとって困難な場合がありますが、保守性、セキュリティ、パフォーマンスの点でメリットがあるため、移行する価値があります。エコシステムが成熟し続けるにつれて、より多くのライブラリやフレームワークが JPMS を採用し、真のモジュール型アプリケーションの構築が容易になっています。
Java 開発の将来はモジュール化されており、Java 開発者にとって JPMS を習得することがますます重要になっています。新しいプロジェクトを開始する場合でも、既存のプロジェクトを維持する場合でも、これらの概念を理解することで、より堅牢で保守しやすいアプリケーションを構築することができます。
このような洞察やストーリーをさらに詳しく知りたい場合は、https://techkoalainsights.com/
をご覧ください。必ず拍手し、私をフォローしてください。 TechKoala Insights そのようなストーリーをもっとご覧ください
インベスター・セントラル |スマートな生活 |
エポックとエコー |
不可解な謎 |
ヒンドゥーヴァ |
エリート開発者 |
JS スクール
以上が解き放たれた Java モジュール: 超安全で超高速なアプリを支える秘密兵器の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。