在软件开发中,我们为了减少软件的复杂度,是不会把所有的功能都塞进一个模块之中的,塞在一个模块之中对于软件的管理无疑是极其困难且复杂的。所以把一个项目拆分为模块无疑是一个好方法
┌ ─ ─ ─ ─ ─ ─ ┐
┌─────────┐
│ │Module A │ │
└─────────┘
┌──────────────┐ split │ ┌─────────┐ │
│Single Project│───────▶ │Module B │
└──────────────┘ │ └─────────┘ │
┌─────────┐
│ │Module C │ │
└─────────┘
└ ─ ─ ─ ─ ─ ─ ┘
对于Maven工程来说,原来是一个大项目:
single-project
├── pom.xml
└── src
现在可以分拆成3个模块:
multiple-projects
├── module-a
│ ├── pom.xml
│ └── src
├── module-b
│ ├── pom.xml
│ └── src
└── module-c
├── pom.xml
└── src
我们能看到的是每一个模块都有属于自己的pom.xml
,然后模块A的pom.xml
是这样的:
4.0.0
com.itranswarp.learnjava
module-a
1.0
jar
module-a
UTF-8
UTF-8
11
11
11
org.slf4j
slf4j-api
1.7.28
ch.qos.logback
logback-classic
1.2.3
runtime
org.junit.jupiter
junit-jupiter-engine
5.5.2
test
之后B的pom.xml
也大同小异,只用把
和
改为自己的就行。这个时候我们就会发现一个很麻烦的事,我们很多地方都是一样的,但是每一个模块的pom都需要我们重复声明出来,那我们能不能用像对象那样继承下来,这样就不用重复声明了呢?Maven无疑是有这样的功能的
我们现在看看简化后的模块结构式如何的
multiple-project
├── pom.xml
├── parent
│ └── pom.xml
├── module-a
│ ├── pom.xml
│ └── src
├── module-b
│ ├── pom.xml
│ └── src
└── module-c
├── pom.xml
└── src
与之对比的是根目录多了一个pom,然后多加了一个"模块"parent,里面没有代码src,只有一个裸的pom。
看了对比之后我们一个一个讲是怎么修改的,结构又是怎么样的
我们先来看parent里面的pom是怎么个事
4.0.0
com.itranswarp.learnjava
parent
1.0
pom
parent
UTF-8
UTF-8
11
11
11
org.slf4j
slf4j-api
1.7.28
ch.qos.logback
logback-classic
1.2.3
runtime
org.junit.jupiter
junit-jupiter-engine
5.5.2
test
我们能发现的是,对于之前的模块A修改其实也不多,修改的分别是
这里我们着重讲一下
,首先我们先明白
这个标签代表了什么,
这个标签他表示打包的方式,常见的值为jar
(Java库)、war
(Web应用)、pom
(父项目)等。这个地方parent
的packaging
设置为pom
,因为它不生成任何可执行的JAR文件,仅提供配置和依赖管理。
看完了parent的代码之后我们就慢慢地去理清简化的思路
首当其冲的无疑就是这个部分,这个地方模块AB都是需要的,而且都是一样的,那么这个元素就是可以被继承的,也就是
UTF-8
UTF-8
11
11
11
其次就是AB都需要的依赖项如slf4j-api
、logback-classic
和junit-jupiter-engine
,以及作用域的设置
org.slf4j
slf4j-api
1.7.28
ch.qos.logback
logback-classic
1.2.3
runtime
org.junit.jupiter
junit-jupiter-engine
5.5.2
test
我们再开看看修改后模块A的pom是怎么样的
4.0.0
com.itranswarp.learnjava
parent
1.0
../parent/pom.xml
module-a
jar
module-a
不得不说有了parent之后,整个模块都变得简洁了起来
在设置好parent
模块后,我们只需要引用parent
作为其他模块的父模块。
首先通过
标签引用parent
模块
com.itranswarp.learnjava
parent
1.0
../parent/pom.xml
有了这些之后就相当于继承了parent里面的元素了。
之后我们再导入自己独有的元素就基本上完成了对此模块的配置
module-a
jar
module-a
继承parent
模块后,模块A和模块B的pom.xml
文件已经大幅简化。所有公共配置项,如UTF-8
编码、Java编译版本、以及日志和测试的依赖库,均已在parent
中配置好。这样,模块A和模块B仅需保留独有的内容,简化了配置并降低了维护成本。
如果模块A需要引用模块B的代码,可以在模块A的
中增加对模块B的依赖项,如下:
com.itranswarp.learnjava
module-b
1.0
通过这一配置,Maven会在构建模块A时自动获取模块B生成的JAR文件,使得模块A可以使用模块B中的代码和功能。
最后的最后,我们配置最后根目录pom的思路就是为了完成所有项目的统一编译:
4.0.0
com.itranswarp.learnjava
build
1.0
pom
build
parent
module-a
module-b
module-c
这样,在根目录执行mvn clean package
时,Maven根据根目录的pom.xml
找到包括parent
在内的共4个
,一次性全部编译。
感谢您看到这里 这可能是最好的Spring教程系列 更多的文章可以到这查看这可能是最好的Spring教程!即便无基础也能看懂的入门Spring,仍在持续更新。,我还在荔枝更新出最详细的Spring教程
参与评论
手机查看
返回顶部