0

0

Java简易模块创建与验证指南

心靈之曲

心靈之曲

发布时间:2025-11-07 16:46:30

|

641人浏览过

|

来源于php中文网

原创

Java简易模块创建与验证指南

本文详细介绍了在java中创建和验证一个简单模块的完整过程。通过定义`module-info.java`文件来声明模块名称并导出包,然后将编译后的模块信息和类文件打包成符合特定结构的jar文件。最后,利用`jar --describe-module`命令验证所创建的jar文件是否成功成为一个模块,从而实现代码的封装与模块化管理。

1. Java模块系统概述

Java模块系统(Java Platform Module System, JPMS),也称为Jigsaw项目,是Java 9引入的一项重要特性。它旨在通过将Java平台和应用程序分解为一系列明确定义的模块来提高应用程序的可靠性、安全性、性能和可维护性。一个Java模块是一个命名的、自描述的代码和数据集合,它明确声明了其所依赖的其他模块以及它向外部世界提供的API。

2. 定义模块信息文件

创建Java模块的第一步是定义其模块描述符,即module-info.java文件。这个文件是模块的蓝图,通常放置在模块的顶级源代码目录中,与模块中的所有包目录同级。它声明了模块的唯一名称以及该模块向外部暴露的包。

例如,如果你的库包含一个名为org.foo.bar.pkgname的包,并且你希望将其作为一个名为org.foo.bar的模块导出,module-info.java文件内容应如下:

// module-info.java
module org.foo.bar {
    // 导出 org.foo.bar.pkgname 包,使其对其他模块可见
    exports org.foo.bar.pkgname;
}
  • module org.foo.bar:定义了模块的唯一名称。遵循反向域名约定是一种推荐的做法。
  • exports org.foo.bar.pkgname:此关键字声明org.foo.bar.pkgname包中的所有公共类型(类和接口)都将对其他模块可见和可用。未显式导出的包将被模块系统封装,外部模块无法直接访问其内容,从而实现强封装。

3. 构建模块化JAR包

在定义了module-info.java文件并编译了所有源代码后,下一步是将其打包成一个模块化的JAR文件。一个模块化的JAR文件与普通JAR文件的关键区别在于module-info.class文件的位置。

立即学习Java免费学习笔记(深入)”;

为了使JAR文件被Java运行时识别为一个模块,编译后的module-info.class文件必须位于JAR包的根目录。典型的模块化JAR文件结构如下:

bar.jar
├── module-info.class  <-- 必须在根目录
├── org/
│   └── foo/
│       └── bar/
│           └── pkgname/
│               ├── X.class
│               └── Y.class
└── META-INF/
    └── MANIFEST.MF (可选,但常见)

你可以使用标准的javac编译器编译module-info.java和所有Java源文件,然后使用jar命令创建这样的JAR包。以下是一个示例构建流程:

假设你的源代码结构如下:

Vondy
Vondy

下一代AI应用平台,汇集了一流的工具/应用程序

下载
project_root/
├── src/main/java/
│   ├── module-info.java
│   └── org/foo/bar/pkgname/
│       ├── MyClassX.java
│       └── MyClassY.java

编译步骤: 首先,编译所有Java源文件,包括module-info.java,并将编译后的类文件输出到一个临时目录(例如mods/org.foo.bar):

# 1. 创建输出目录
mkdir -p mods/org.foo.bar

# 2. 编译模块信息文件和所有Java类文件
# -d 指定编译输出目录
javac -d mods/org.foo.bar src/main/java/module-info.java src/main/java/org/foo/bar/pkgname/*.java

打包步骤: 然后,使用jar命令创建模块化JAR包。关键在于使用-C选项将编译输出目录中的内容打包到JAR的根目录:

# 3. 创建模块化JAR包
# --create:创建新的JAR包
# --file:指定JAR包名称
# --module-version:可选,指定模块版本
# -C mods/org.foo.bar .:将 mods/org.foo.bar 目录下的所有内容打包到 JAR 的根目录
jar --create --file bar.jar --module-version 1.0 -C mods/org.foo.bar .

执行上述命令后,你将在当前目录中得到bar.jar文件,它是一个符合Java模块规范的模块化JAR包。

4. 验证模块

完成JAR包的创建后,你可以使用jar --describe-module命令来验证它是否成功被识别为一个Java模块,并查看其模块描述符信息。

jar --describe-module --file bar.jar

如果bar.jar是一个有效的模块,该命令将输出其模块名称、版本(如果有)、导出的包以及其依赖关系等信息。例如,你可能会看到类似如下的输出:

bar.jar
org.foo.bar@1.0
exports org.foo.bar.pkgname
requires java.base mandated

输出中的requires java.base mandated表示该模块隐式依赖于Java平台的基础模块java.base。java.base模块包含了所有Java应用程序的基础API,是所有Java模块的默认依赖,因此即使在module-info.java中没有显式声明,它也会被自动添加。

5. 总结与注意事项

创建Java模块的核心在于正确地定义module-info.java文件,并确保编译后的module-info.class文件位于最终JAR包的根目录。这种结构是Java运行时识别模块的关键。通过模块化,你可以更好地管理代码的可见性和依赖关系,从而构建更健壮、更安全、更易于维护的应用程序。

本教程仅涉及最简单的模块创建和包导出。在实际开发中,Java模块系统还包括其他重要的指令,例如:

  • requires:声明对其他模块的依赖。
  • uses:声明模块使用服务接口。
  • provides ... with ...:声明模块提供服务接口的实现。
  • opens:允许反射访问特定包中的所有类型。

理解并合理运用这些特性,将能充分发挥Java模块系统的强大功能,优化大型项目的结构和管理。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1960

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

658

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2403

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

47

2026.01.19

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

891

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

32

2025.12.06

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

42

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

79

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

234

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.4万人学习

C# 教程
C# 教程

共94课时 | 11.3万人学习

Java 教程
Java 教程

共578课时 | 82万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号