网站首页 > 技术文章 正文
Person类在com.jdojo.person模块中,它使用com.jdojo.address模块中的Address类型中的字段。 这意味着com.jdojo.person模块读取com.jdojo.address模块。 这通过com.jdojo.person模块声明中的requires语句指示:
requires com.jdojo.address;
requires语句用于指定一个模块对另一个模块的依赖。 如果模块读取另一个模块,则第一个模块在其声明中需要有一个requires语句。 requires语句的一般语法如下:
requires [transitive] [static] <module>;
这里,<module>是当前模块读取的另一个模块的名称。 transitive 和static修饰符都是可选的。 如果存在static修饰符,则<module>模块在编译时是必需的,但在运行时是可选的。 transitive 修饰符意味着读取当前模块的模块隐含地读取<module>模块,也就是创建传递依赖。
每个模块都隐式依赖java.base模块。 如果一个模块没有声明依赖java.base模块,编译器将添加一个requires语句,将java.base模块作为依赖模块。 名为com.jdojo.common的模块的以下两个模块声明是等效的:
// Declaration #1 module com.jdojo.common { // Compiler will add a read to the java.base module} // Declaration #2 module com.jdojo.common { // Add a read to the java.base module explicitly requires java.base; }
com.jdojo.person模块的声明包含一个requires语句,这意味着在编译时和运行时都需要com.jdojo.address模块。 编译com.jdojo.person模块时,必须在模块路径中包含com.jdojo.address模块。 如果使用NetBeans IDE,可以在模块路径中包含NetBeans项目或模块化JAR。 右键单击NetBeans中的com.jdojo.person项目,然后选择“属性”。具体如下所示:
最后点击“确定”按钮。
com.jdojo.person模块还导出com.jdojo.person包,因此该包中的公共类型(例如Person类)也可以被其他模块使用。
接下来,我们建立一个包含main方法的类:
// Main.javapackage com.jdojo.person; import com.jdojo.address.Address; public class Main { public static void main(String[] args) { Person john = new Person(1001, "John", "Jacobs"); String fName = john.getFirstName(); String lName = john.getLastName(); Address addr = john.getAddress(); System.out.printf("%s %s%n", fName, lName); System.out.printf("%s%n", addr.getLine1()); System.out.printf("%s, %s %s%n", addr.getCity(), addr.getState(), addr.getZip()); } }
运行此类,得到输出:
此时,还可以使用命令提示符运行此示例。 需要将编译的分解目录或com.jdojo.person和com.jdojo.address模块的模块化JAR包含到模块路径中。 以下命令使用两个NetBeans项目下的build\classes目录中编译的类:
构建包含模块的NetBeans项目时,模块的模块化JAR存储在NetBeans项目的dist目录中。 当构建com.jdojo.person项目时,它将在E:\Java\com.jdojo.person\dist目录中创建一个com.jdojo.person.jar文件。 当在NetBeans中构建项目时,它还会重建当前项目所依赖的所有项目。 对于此示例,构建com.jdojo.person项目也将重建com.jdojo.address项目。 构建com.jdojo.person模块后,可以使用以下命令运行此示例:
猜你喜欢
- 2024-10-18 MyBatisPlus又在搞事了!发布神器,一个依赖轻松搞定权限问题
- 2024-10-18 史上硬核!Jar 包依赖冲突排查思路和解决方法
- 2024-10-18 小白都能看懂的 Spring 源码揭秘之依赖注入(DI)源码分析
- 2024-10-18 Spring-bean的循环依赖以及解决方式
- 2024-10-18 Maven技术方案最全手册 maven详细教程
- 2024-10-18 JAVA编程规范之二方库依赖 java方法库
- 2024-10-18 Spring依赖注入原理分析 spring依赖注入作用
- 2024-10-18 简单2步实现maven打包java工程并将依赖jar输出到指定目录
- 2024-10-18 怎么进阶学好Java 如何用Spring解决循环依赖
- 2024-10-18 Spring 源码分析之 bean 依赖注入原理(注入属性)
你 发表评论:
欢迎- 11-19零基础学习!数据分析分类模型「支持向量机」
- 11-19机器学习 | 算法笔记(三)- 支持向量机算法以及代码实现
- 11-19我以前一直没有真正理解支持向量机,直到我画了一张图
- 11-19研一小姑娘分享机器学习之SVM支持向量机
- 11-19[机器学习] sklearn支持向量机
- 11-19支持向量机
- 11-19初探支持向量机:用大白话解释、原理详解、Python实现
- 11-19支持向量机的核函数
- 最近发表
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)