当前位置: 首页 > news >正文

Module-info.java文件

文章目录

      • 一、module-info.java 的所有关键字
        • 1. 模块定义关键字
        • 2. 依赖声明关键字
        • 3. 包导出关键字
        • 4. 服务相关关键字
        • 5. 反射访问关键字
      • 二、关键字表
      • 三、关键字的搭配与实际场景
        • 1. 依赖与导出
        • 2. 服务提供与消费
        • 3. 反射控制
      • 四、注意事项
      • 五、完整示例
      • 六、总结

一、module-info.java 的所有关键字

在 Java 模块化系统(JPMS)中(jdk9后的新特性),module-info.java 文件使用以下关键字来定义模块的结构、依赖和服务。以下是按照功能分组的列表:

1. 模块定义关键字
  • module

    • 作用:定义模块的名称,标志模块声明的开始。

    • 语法:module <模块名> { … }

    • 示例:

      module com.example.myapp {
          // 模块内容 
          }
      
    • 说明:模块名通常遵循反向域名规则(如 com.example.myapp),是模块的唯一标识。

2. 依赖声明关键字
  • requires

    • 作用:声明当前模块依赖的其他模块。

    • 语法:requires [修饰符] <模块名>;

    • 修饰符(可选):

      • transitive:依赖是传递的,依赖当前模块的模块也会自动依赖它。
      • static:依赖是可选的,编译时需要,运行时可以没有。
    • 示例:

      module com.example.myapp {
          requires java.base;         // 默认依赖基础模块   
          requires transitive java.sql; // 传递依赖    
          requires static java.logging; // 可选依赖 
      }
      
    • 说明:java.base 是所有模块的默认依赖,无需显式声明。

3. 包导出关键字
  • exports

    • 作用:声明当前模块的某个包可以被其他模块访问。

    • 语法:

      • exports <包名>;(开放给所有模块)
      • exports <包名> to <模块名列表>;(限制给特定模块)
    • 示例:

      module com.example.myapp {
          exports com.example.myapp.api;           // 开放给所有模块    
          exports com.example.myapp.util to com.example.client; // 仅限特定模块 
      }
      
    • 说明:

      • 包必须存在于模块中,否则编译报错。
      • 未导出的包对外部模块不可见。
4. 服务相关关键字
  • provides

    • 作用:声明当前模块为某个服务接口提供具体实现。

    • 语法:provides <接口全限定名> with <实现类全限定名>;

    • 示例:

      module com.example.myapp {    
          provides com.example.service.MyService with com.example.myapp.MyServiceImpl; 
      }
      
    • 说明:

      • 与 with 配合使用,指定实现类。
      • 表示模块是服务提供者,供其他模块通过 ServiceLoader 加载。
  • with

    • 作用:配合 provides 使用,指定服务接口的具体实现类。

    • 语法:出现在 provides 语句中,with 后接实现类的全限定名。

    • 示例:

      provides javax.tools.JavaCompiler with com.example.myapp.MyCompiler;
      
    • 说明:

      • 实现类必须是接口的合法实现(实现接口或继承抽象类)。
      • 可以为一个接口提供多个实现,用多个 with 分隔。
  • uses

    • 作用:声明当前模块使用某个服务接口,期待其他模块提供实现。

    • 语法:uses <接口全限定名>;

    • 示例:

      module com.example.myapp {    
          uses com.example.service.MyService; 
      }
      
    • 说明:

      • 表示模块是服务消费者,通过 ServiceLoader 加载接口实现。
      • 常与 provides 配合使用,形成服务提供-消费模式。
5. 反射访问关键字
  • opens

    • 作用:声明某个包对反射开放,允许其他模块在运行时通过反射访问。

    • 语法:

      • opens <包名>;(开放给所有模块)
      • opens <包名> to <模块名列表>;(限制给特定模块)
    • 示例:

      module com.example.myapp {    
          opens com.example.myapp.data;            // 开放给所有模块反射    
          opens com.example.myapp.config to com.example.client; // 仅限特定模块 
      }
      
    • 说明:

      • 不影响编译时访问,只开放运行时反射(如 setAccessible)。
      • 适用于需要反射的场景(如序列化框架)。
  • open

    • 作用:声明整个模块对反射开放,所有包都可以被反射访问。

    • 语法:open module <模块名> { … }

    • 示例:

      open module com.example.myapp {    
          exports com.example.myapp.api; 
      }
      
    • 说明:

      • 是模块级别的反射开放,比 opens 更彻底。
      • 常用于兼容非模块化代码或调试。

二、关键字表

关键字功能示例
module定义模块module com.example.myapp {}
requires声明依赖模块requires java.sql;
exports导出包给其他模块exports com.example.myapp.api;
provides提供服务接口实现provides X with Y;
with指定服务实现的类with com.example.myapp.MyServiceImpl;
uses声明使用服务接口uses javax.tools.JavaCompiler;
opens开放包给反射访问opens com.example.myapp.data;
open定义开放模块(全部包可反射)open module com.example.myapp {}

三、关键字的搭配与实际场景

1. 依赖与导出
  • requires + exports:最常见组合,用于模块间的依赖和接口共享。

    module com.example.client {    
        requires com.example.myapp;    // 使用 com.example.myapp 导出的包 
    } 
    module com.example.myapp {    
        exports com.example.myapp.api; 
    }
    
2. 服务提供与消费
  • provides + with + uses:实现插件化机制。

    module com.example.provider {    
        provides com.example.service.MyService with com.example.provider.MyServiceImpl; 
    } 
    module com.example.consumer {    
        uses com.example.service.MyService; 
    }
    
    • 消费端代码:

      ServiceLoader<MyService> loader = ServiceLoader.load(MyService.class); 
      for (MyService service : loader) {    
          service.doSomething(); 
      }
      
3. 反射控制
  • opens + exports:既允许编译时访问,又开放运行时反射。

    module com.example.myapp {    
        exports com.example.myapp.api;   
        opens com.example.myapp.data; 
    }
    

四、注意事项

  1. 包存在性
    • exports 和 opens 声明的包必须在模块中存在,否则编译报错。
    • 空包(无类或资源)可能导致错误。
  2. 服务机制
    • provides 的实现类必须是 uses 接口的合法实现。
    • 一个接口可以有多个 with 实现。
  3. 修饰符限制
    • requires 的 transitive 和 static 不能同时使用。
    • exports 和 opens 的 to 后接模块名列表,用逗号分隔。

五、完整示例

以下是一个综合所有关键字的 module-info.java:

open module com.example.myapp {    
    requires transitive java.sql;           // 传递依赖    
    requires static java.logging;           // 可选依赖        
    exports com.example.myapp.api;          // 导出 API 包    
    exports com.example.myapp.util to com.example.client; // 限制导出        
    provides com.example.service.MyService         with com.example.myapp.MyServiceImpl; // 服务实现        
    uses com.example.service.MyService;     // 使用服务接口        
    opens com.example.myapp.data;           // 开放反射    
    opens com.example.myapp.config to com.example.client; // 限制开放 
}

六、总结

module-info.java 的关键字虽然数量有限,但功能强大,涵盖了模块定义、依赖管理、包导出、服务提供和反射控制等核心特性。

相关文章:

  • Java 接口与实现类:为什么接口不能直接创建对象?
  • 数据库导出
  • 【2】VS Code 新建上位机项目---C#面向对象编程
  • IDEA中.gitignore未忽略指定文件的问题排查与解决
  • J-LangChain,用Java实现LangChain编排!轻松加载PDF、切分文档、向量化存储,再到智能问答
  • 【含文档+PPT+源码】基于过滤协同算法的旅游推荐管理系统设计与实现
  • YOLOv8+QT搭建目标检测项目
  • 推荐3个背景渐变色的wordpress主题
  • 深度生成模型(一)——具身智能综述与算法分类简介
  • 一劳永逸解决vsocde模块import引用问题
  • smolagents学习笔记系列(番外一)使用DeepSeek API Key + CodeAgent
  • 有没有什么免费的AI工具可以帮忙做简单的ppt?
  • 串口解析的服务器流程优化
  • javaweb文件上传:@MultipartConfig注解与Apache Commons FileUpload对比
  • 建筑兔零基础自学python记录32|学过的函数代码记录19-25
  • 判断一个文件中以三个#号开头有多少行的shell脚本怎么写
  • C语言(15)-------------->一维数组
  • Kubernetes (K8S) 核心原理深度剖析:从架构设计到运行机制
  • 【音视频】编解码相关概念总结
  • 什么是Ollama?什么是GGUF?二者之间有什么关系?
  • 减重人生|吃得越少越好?比体重秤上的数字,更有意义的是什么?
  • 多所院校高规格召开考研动员会,有学院考研报名率达84%
  • 专访|金七猫奖得主:以非遗为舟,在现实题材中疗愈与成长
  • 上海徐汇 “家 + 书屋”,创新服务广大家庭
  • 海南保亭警方通报“两飞车党紧追女童”:两名初中生认错道歉
  • 十大券商看后市|A股指数有望进一步缓步推高,淡化短期波动