0

0

在Java里什么是模块化系统_Java模块机制解析

P粉602998670

P粉602998670

发布时间:2026-02-07 14:58:02

|

339人浏览过

|

来源于php中文网

原创

module-info.java 是模块强制入口文件,须置于源码根目录且命名规范;exports 解决包可见性,opens 才支持反射访问私有成员;混用模块路径与类路径会生成不可控的自动模块。

在java里什么是模块化系统_java模块机制解析

module-info.java 是 Java 模块化系统的“身份证”——没有它,JVM 就不认为你写的是模块;有了它,但写错一行,就可能编译失败、类找不到、反射报 IllegalAccessError


module-info.java 怎么写才不被 JVM 拒绝

它不是可选配置,而是模块的强制入口文件,必须放在源码根目录(如 src/main/java/module-info.java),且只能有一个。常见错误包括:

  • module-info.java 放在包目录下(比如 src/main/java/com/example/ 里),导致编译器根本找不到它
  • 模块名含非法字符(如短横线 -、数字开头),JVM 要求符合 Java 标识符规则,推荐用点分命名(com.example.user
  • requires 写了不存在的模块名,比如 requires com.fasterxml.jackson.core;,但没把 Jackson JAR 放进模块路径,编译时不会报错,运行时才崩
  • 导出包路径拼错,比如写了 exports com.example.api;,但实际类在 com.example.service.api,外部模块 import 时会提示 package not visible

正确示例:

module com.example.user {
    requires java.base;
    requires java.sql;
    exports com.example.user.api;
    opens com.example.user.model to com.example.user.test;
}

为什么加了 exports 还是访问不到类

导出(exports)只解决“包可见性”,不等于“所有类都可访问”。真正生效还要看三重过滤:

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

  • 包级可见:必须 exports com.example.api;,否则连包名都解析不了
  • 类级可见:类本身得是 public,内部类默认不可见,除非显式声明为 public static
  • 成员级可见:方法/字段也得是 public;若要用反射访问非 public 成员,必须用 opens(不是 exports!)

典型误操作:以为 exports com.example.model; 就能让 Spring 自动注入 @Entity 类,结果报 java.lang.IllegalAccessError: class com.example.model.User cannot access its constructor——这是因为 JPA 反射构造实例,而 model 包没被 opens,需改成:opens com.example.model to java.persistence;

云点滴客户关系管理CRM OA系统
云点滴客户关系管理CRM OA系统

云点滴客户解决方案是针对中小企业量身制定的具有简单易用、功能强大、永久免费使用、终身升级维护的智能化客户解决方案。依托功能强大、安全稳定的阿里云平 台,性价比高、扩展性好、安全性高、稳定性好。高内聚低耦合的模块化设计,使得每个模块最大限度的满足需求,相关模块的组合能满足用户的一系列要求。简单 易用的云备份使得用户随时随地简单、安全、可靠的备份客户信息。功能强大的报表统计使得用户大数据分析变的简单,

下载

模块路径(--module-path)和类路径(-cp)混用会怎样

一旦用了 --module-path,JVM 就进入“模块模式”,此时 -cp 里的 JAR 全部变成自动模块(Automatic Module),名字来自 JAR 文件名(如 jackson-databind-2.15.2.jar → 模块名 jackson.databind),它们能访问所有包,但自身无法被 exports 控制,破坏封装性

  • 后果:你的 com.example.user 模块 requires jackson.databind; 是合法的,但 jackson 作为自动模块,会把所有包暴露给整个模块图,相当于白写了 exports
  • 更糟的是:多个同名自动模块(比如两个不同版本的 log4j-core.jar)会导致启动失败,报 ModuleResolutionException: Duplicate module
  • 解法:第三方库尽量用模块化版本(如 jackson-bom 提供的模块化 JAR),或用 jlink + jdeps --module 分析依赖树,提前发现冲突

什么时候该用 opens 而不是 exports

opens 不是“导出包”,而是“开放反射入口”。它只在需要运行时深度元数据操作时才用,比如:

  • JPA/Hibernate 实体类的字段注入
  • JSON 序列化框架(Jackson/Gson)读写私有字段
  • 测试框架(JUnit 5)反射调用 @BeforeEach 方法

关键区别

  • exports com.example.api; → 其他模块能 import com.example.api.UserService;
  • opens com.example.model; → 其他模块能 User.class.getDeclaredField("id").setAccessible(true);
  • opens com.example.model to com.fasterxml.jackson.databind; → 仅对 Jackson 模块开放,其他模块仍不能反射

滥用 opens 等于主动撕开封装边界,生产环境应严格限制范围,宁可改字段为 public 或加 getter/setter,也不无条件 opens 整个包。

模块化不是加个 module-info.java 就完事,真正的难点在于:哪些包该导出、哪些该开放、哪些必须锁死,以及当 Spring、Hibernate、Jackson 这些框架绕过模块检查时,你得比它们更清楚边界在哪。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

118

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

72

2026.01.26

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

430

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

542

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

314

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

79

2025.09.10

hibernate和mybatis有哪些区别
hibernate和mybatis有哪些区别

hibernate和mybatis的区别:1、实现方式;2、性能;3、对象管理的对比;4、缓存机制。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

150

2024.02.23

Hibernate框架介绍
Hibernate框架介绍

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

86

2025.08.06

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

39

2026.02.06

热门下载

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

精品课程

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

共23课时 | 3.3万人学习

C# 教程
C# 教程

共94课时 | 8.8万人学习

Java 教程
Java 教程

共578课时 | 59.7万人学习

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

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