文章目录

  • 1. 代码组织形式
    • 1.1 平铺
    • 1.2 父子结构
  • 2. 打包问题
    • 2.1 继承
    • 2.2 聚合
  • 3. 小结

因为最近有小伙伴问到了,所以我想和大家随便扯扯 Maven 项目中代码的组织形式这个问题。

其实也不是啥大问题,但是如果不懂的话,就像雾里看花,始终不能看的明明白白,懂了就像一层窗户纸,捅破就好了。

所以我们就简单扯几句。

1. 代码组织形式

首先来说说代码组织形式。

一般来说,就两种比较常见的形式:

  • 平铺
  • 父子结构

这两种形式松哥在不同的项目中都有遇到过,所以我们就不说孰优孰劣,单纯来说这两种方案。

1.1 平铺

平铺的代码类似下面这样:

├── parent
│   ├── pom.xml
│   └── src
│       ├── main
│       │   ├── java
│       │   └── resources
│       └── test
│           └── java
├── vhr-dao
│   ├── pom.xml
│   ├── src
│   │   ├── main
│   │   │   ├── java
│   │   │   └── resources
│   │   └── test
│   │       └── java
└── vhr-service├── pom.xml├── src│   ├── main│   │   ├── java│   │   └── resources│   └── test│       └── java

如下图:

可以看到,在这种结构下,parent 父工程和各个子工程从代码组织形式上来看都是平级的,都处于同一个目录下。

不过仔细查看 pom.xml 文件,还是能够清晰的看到这三个 module 的父子关系的:

parent:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.javaboy</groupId><artifactId>parent</artifactId><packaging>pom</packaging><version>1.0-SNAPSHOT</version><modules><module>../vhr-dao</module><module>../vhr-service</module></modules></project>

可以看到,在指定 module 时,由于 vhr-dao 和 vhr-service 和 parent 的 pom.xml 不在同一个目录下,所以这里使用了相对路径,相对路径的参考依据是 parent 的 pom.xml 文件位置。

vhr-dao:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>parent</artifactId><groupId>org.javaboy</groupId><version>1.0-SNAPSHOT</version><relativePath>../parent/pom.xml</relativePath></parent><modelVersion>4.0.0</modelVersion><artifactId>vhr-dao</artifactId></project>

可以看到,relativePath 节点中,通过相对路径指定了 parent 的 pom.xml 文件位置,这个相对路径的参考依据是子模块的 pom.xml 文件。

vhr-service:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>parent</artifactId><groupId>org.javaboy</groupId><version>1.0-SNAPSHOT</version><relativePath>../parent/pom.xml</relativePath></parent><modelVersion>4.0.0</modelVersion><artifactId>vhr-service</artifactId></project>

这个和 vhr-dao 的差不多,不赘述。

1.2 父子结构

父子结构则类似于下面这样:

├── maven_parent
│   ├── pom.xml
│   ├── vhr-dao
│   │   ├── pom.xml
│   │   └── src
│   │       ├── main
│   │       │   ├── java
│   │       │   └── resources
│   │       └── test
│   │           └── java
│   └── vhr-service
│       ├── pom.xml
│       └── src
│           ├── main
│           │   ├── java
│           │   └── resources
│           └── test
│               └── java

如下图:

这种父子结构的看起来就非常的层次分明了,parent 和各个 module 一眼就能看出来,我们从 GitHub 上下载的很多开源项目如 Shiro,都是这种结构。

不过文件夹的层级并不能说明任何问题,关键还是要看 pom.xml 中的定义,接下来我们就来看看 parent 的 pom.xml 和各个子模块的 pom.xml 有何异同。

maven_parent:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.javaboy</groupId><artifactId>maven_parent</artifactId><packaging>pom</packaging><version>1.0-SNAPSHOT</version><modules><module>vhr-dao</module><module>vhr-service</module></modules></project>

和前面不同的是,这里声明 modules 不需要相对路径了(其实还是相对路径,只是不需要 ../ 了),因为各个子模块和 parent 的 pom.xml 文件处于同一目录下。

vhr-dao:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>maven_parent</artifactId><groupId>org.javaboy</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>vhr-dao</artifactId></project>

这里也不需要通过 relativePath 节点去指定 parent 的 pom.xml 文件位置了,因为 parent 的 pom.xml 和各个子模块处于同一目录下。

vhr-service:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>maven_parent</artifactId><groupId>org.javaboy</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>vhr-service</artifactId></project>

2. 打包问题

2.1 继承

有的时候,单纯只是想通过 parent 来统一管理不同的项目的依赖,并非一个聚合项目。

这个时候只需要去掉 parent 的 pom.xml 中的 modules 节点及其中的内容即可,这样就不是聚合工程了,各个子模块也可以独立打包。

2.2 聚合

当然很多情况我们是聚合工程。

聚合工程的话,一般松哥是建议大家从 parent 处统一进行打包:

这样可以确保打包到的是最新的代码。

当然还有另外一种操作流程:

  1. 首先将 parent 安装到本地仓库。
  2. 然后分别将 model、dao 以及 service 等模块安装到本地仓库。
  3. 最后 web 模块就可以独立打包了。

如果使用这种操作流程,需要注意一点,就是每个模块代码更新之后,要及时安装到本地仓库,否则当 web 模块独立打包时,用到的其他模块就不是最新的代码。

3. 小结

好啦,几个 Maven 中的小问题,窗户纸捅破了就豁然开朗啦~

闲扯Maven项目代码组织形式相关推荐

  1. Maven项目代码组织形式

    1.常见的maven项目两种代码组织形式 1.1.平铺 可以看到,在这种结构下,parent 父工程和各个子工程从代码组织形式上来看都是平级的,都处于同一个目录下. 不过仔细查看 pom.xml 文件 ...

  2. IDEA JDK1.8 ProGuard 混淆Maven项目代码

    直接复制到pom中即可使用 <build><plugins><plugin><groupId>com.github.wvengen</groupI ...

  3. Maven项目代码中定位resources文件夹下的文件目录,解决文件不存在的问题

    在IDEA中对于文件的路径会提示: ../resources/xxx.txt 不要这样!!!,会报错找不到路径,改为: src/main/resources/xxx.txt

  4. Maven | 05.Maven项目结构及Maven命令

    文章目录 参考视频 1.Maven项目结构 2.使用命令构建Maven项目 2.1.Maven构建命令(在DOS窗口中) 2.2.构建Maven项目 参考视频 06-第一个Maven程序-Maven项 ...

  5. Java代码安装maven jar_Java中Maven项目导出jar包配置的示例代码

    具体代码如下所示: src/main/java src/main/resources ${project.build.directory} **/*.java src/test/java src/te ...

  6. idea的maven项目修改java代码重启后无效

    修改java代码必须先clean下maven项目后重新运行才能生效,否则修改java代码重启后还是等于没重启,从class文件看出来根本没编译.还是老代码,所以确定是这问题,在idea的maven设置 ...

  7. 在IDEA中创建maven项目编写java代码操作HDFS集群

    一.安装win10编译过的hadoop 1.将编译好的hadoop包放在非中文目录 2.配置HADOOP_HOME环境变量 3.将hadoop包的bin目录加到PATH环境变量中 二.在idea中创建 ...

  8. 【MAVEN】Maven依赖和项目代码分离打包,依赖包自动同步到服务器

    Maven分离lib打包,lib包自动同步,加速项目部署 目标 整体步骤 Maven配置 1. 分离打包:配置打包.将依赖jar拷贝到外部 2. 编辑MANIFEST.MF 本地<=>服务 ...

  9. idea使用svn拉取项目代码_IntelliJ IDEA 14 拉取SVN maven 多模块项目 部署tomcat 详细图解!...

    二话不说 进入主题 我们创建空项目实际上是项目空间 进入主界面 想用svn必须先启用它 选择Subversion 拉取 svn项目 你会发现这里检测不到目录 我们进入 File>Seting 里 ...

最新文章

  1. Linux服务名重命名
  2. 80%的Oracle JDK用户另有想法
  3. 计算机视觉开源库OpenCV添加文字cv2.putText()参数详解
  4. 关于Cloud各种组件的停更/升级/替换
  5. 傲腾内存 可以用ghost系统_玩机小贴士:Intel傲腾内存你用过没有?
  6. 教你如何监控 Java 线程池运行状态
  7. 查看openssh版本_OpenSSH命令注入漏洞复现(CVE202015778)
  8. Windows下RabbitMQ安装及入门
  9. 为什么xgboost/gbdt在调参时为什么树的深度很少就能达到很高的精度?
  10. java怎么编译_java怎么编译运行?java有哪些编译方法?
  11. C语言课设图书管理系统(大作业)
  12. MSN蠕虫Myalbum2007.zip专杀工具
  13. 花大价钱买十五年前的交换机架构的“分布式KVM坐席/数字KVM坐席”???
  14. 【考研政治笔记】唯物论中物质观与意识观辨析
  15. refind引导的win10+ubuntu18.04开机启动
  16. java常见的设计模式
  17. 计算机专业学习资源合集 | 视频电子书资源
  18. NYOJ_1275 导弹发射 【LIS】
  19. 多元线性回归分析练习题
  20. android studio 绘制时钟刻度表盘的虚拟动画。

热门文章

  1. thinkpad x250装黑苹果教程_[黑苹果]x250 黑苹果历险记
  2. mysql安装时的英文_安装MySQL遇到的常见英文翻译
  3. 【js逆向】md5加密参数破解
  4. 数据集fer2013
  5. HDMI切换器的各种版本能不能互通?
  6. Day 112/200 Macbook Pro 电脑按键脱落怎么办?
  7. 惊蛰时节,最好看的微信公众号图文排版,全在这里了
  8. xmanager linux 远程桌面,Windows系统下通过xmanager远程桌面控制Linux
  9. Python PDF文件转Word格式
  10. 【论文学习】G-Rep:面向任意目标检测的高斯表示