构建工具.md 4.3 KB
Newer Older
C
CyC2018 已提交
1
[🍉 点击订阅面试进阶专栏 ](https://xiaozhuanlan.com/CyC2018)
C
CyC2018 已提交
2 3 4 5 6 7 8 9 10
<!-- GFM-TOC -->
* [一、构建工具的作用](#一构建工具的作用)
* [二、Java 主流构建工具](#二java-主流构建工具)
* [三、Maven](#三maven)
* [参考资料](#参考资料)
<!-- GFM-TOC -->


# 一、构建工具的作用
C
CyC2018 已提交
11

C
CyC2018 已提交
12
构建工具是用于构建项目的自动化工具,主要包含以下工作:
C
CyC2018 已提交
13

C
CyC2018 已提交
14
## 依赖管理
C
CyC2018 已提交
15

C
CyC2018 已提交
16
不再需要手动导入 Jar 依赖包,并且可以自动处理依赖关系,也就是说某个依赖如果依赖于其它依赖,构建工具可以帮助我们自动处理这种依赖管理。
C
CyC2018 已提交
17

C
CyC2018 已提交
18
## 运行单元测试
C
CyC2018 已提交
19

C
CyC2018 已提交
20
不再需要在项目代码中添加测试代码,从而避免了污染项目代码。
C
CyC2018 已提交
21

C
CyC2018 已提交
22
## 将源代码转化为可执行文件
C
CyC2018 已提交
23 24 25

包含预处理、编译、汇编、链接等步骤。

C
CyC2018 已提交
26
## 将可执行文件进行打包
C
CyC2018 已提交
27

C
CyC2018 已提交
28
不再需要使用 IDE 将应用程序打包成 Jar 包。
C
CyC2018 已提交
29

C
CyC2018 已提交
30
## 发布到生产服务器上
C
CyC2018 已提交
31

C
CyC2018 已提交
32
不再需要通过 FTP 将 Jar 包上传到服务器上。
C
CyC2018 已提交
33

C
CyC2018 已提交
34
# 二、Java 主流构建工具
C
CyC2018 已提交
35

C
CyC2018 已提交
36
主要包括 Ant、Maven 和 Gradle。
C
CyC2018 已提交
37

C
CyC2018 已提交
38
<div align="center"> <img src="pics/897503d0-59e3-4752-903d-529fbdb72fee.jpg"/> </div><br>
C
CyC2018 已提交
39

C
CyC2018 已提交
40
Gradle 和 Maven 的区别是,它使用 Groovy 这种特定领域语言(DSL)来管理构建脚本,而不再使用 XML 这种标记性语言。因为项目如果庞大的话,XML 很容易就变得臃肿。
C
CyC2018 已提交
41

C
CyC2018 已提交
42
例如要在项目中引入 Junit,Maven 的代码如下:
C
CyC2018 已提交
43 44

```xml
C
CyC2018 已提交
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
<?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>jizg.study.maven.hello</groupId>
   <artifactId>hello-first</artifactId>
   <version>0.0.1-SNAPSHOT</version>

   <dependencies>
          <dependency>
               <groupId>junit</groupId>
               <artifactId>junit</artifactId>
               <version>4.10</version>
               <scope>test</scope>
          </dependency>
   </dependencies>
C
CyC2018 已提交
62 63 64
</project>
```

C
CyC2018 已提交
65
而 Gradle 只需要几行代码:
C
CyC2018 已提交
66 67

```java
C
CyC2018 已提交
68 69
dependencies {
    testCompile "junit:junit:4.10"
C
CyC2018 已提交
70 71 72
}
```

C
CyC2018 已提交
73
# 三、Maven
C
CyC2018 已提交
74

C
CyC2018 已提交
75
## 概述
C
CyC2018 已提交
76 77 78

提供了项目对象模型(POM)文件来管理项目的构建。

C
CyC2018 已提交
79
## 仓库
C
CyC2018 已提交
80 81 82

仓库的搜索顺序为:本地仓库、中央仓库、远程仓库。

C
CyC2018 已提交
83 84 85
- 本地仓库用来存储项目的依赖库;
- 中央仓库是下载依赖库的默认位置;
- 远程仓库,因为并非所有的库存储在中央仓库,或者中央仓库访问速度很慢,远程仓库是中央仓库的补充。
C
CyC2018 已提交
86

C
CyC2018 已提交
87
## POM
C
CyC2018 已提交
88

C
CyC2018 已提交
89
POM 代表项目对象模型,它是一个 XML 文件,保存在项目根目录的 pom.xml 文件中。
C
CyC2018 已提交
90 91 92

```xml
<dependency>
C
CyC2018 已提交
93 94 95 96
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.12</version>
    <scope>test</scope>
C
CyC2018 已提交
97 98 99
</dependency>
```

C
CyC2018 已提交
100
[groupId, artifactId, version, packaging, classifier] 称为一个项目的坐标,其中 groupId、artifactId、version 必须定义,packaging 可选(默认为 Jar),classifier 不能直接定义的,需要结合插件使用。
C
CyC2018 已提交
101

C
CyC2018 已提交
102

C
CyC2018 已提交
103 104 105 106
- groupId:项目组 Id,必须全球唯一;
- artifactId:项目 Id,即项目名;
- version:项目版本;
- packaging:项目打包方式。
C
CyC2018 已提交
107

C
CyC2018 已提交
108
## 依赖原则
C
CyC2018 已提交
109

C
CyC2018 已提交
110
### 1. 依赖路径最短优先原则
C
CyC2018 已提交
111 112

```html
C
CyC2018 已提交
113 114
A -> B -> C -> X(1.0)
A -> D -> X(2.0)
C
CyC2018 已提交
115
```
C
CyC2018 已提交
116
由于 X(2.0) 路径最短,所以使用 X(2.0)。
C
CyC2018 已提交
117

C
CyC2018 已提交
118
### 2. 声明顺序优先原则
C
CyC2018 已提交
119 120

```html
C
CyC2018 已提交
121 122
A -> B -> X(1.0)
A -> C -> X(2.0)
C
CyC2018 已提交
123 124
```

C
CyC2018 已提交
125
在 POM 中最先声明的优先,上面的两个依赖如果先声明 B,那么最后使用 X(1.0)。
C
CyC2018 已提交
126

C
CyC2018 已提交
127
### 3. 覆写优先原则
C
CyC2018 已提交
128

C
CyC2018 已提交
129
子 POM 内声明的依赖优先于父 POM 中声明的依赖。
C
CyC2018 已提交
130

C
CyC2018 已提交
131
## 解决依赖冲突
C
CyC2018 已提交
132

C
CyC2018 已提交
133
找到 Maven 加载的 Jar 包版本,使用 `mvn dependency:tree` 查看依赖树,根据依赖原则来调整依赖在 POM 文件的声明顺序。
C
CyC2018 已提交
134

C
CyC2018 已提交
135
# 参考资料
C
CyC2018 已提交
136

C
CyC2018 已提交
137 138 139 140 141
- [POM Reference](http://maven.apache.org/pom.html#Dependency_Version_Requirement_Specification)
- [What is a build tool?](https://stackoverflow.com/questions/7249871/what-is-a-build-tool)
- [Java Build Tools Comparisons: Ant vs Maven vs Gradle](https://programmingmitra.blogspot.com/2016/05/java-build-tools-comparisons-ant-vs.html)
- [maven 2 gradle](http://sagioto.github.io/maven2gradle/)
- [新一代构建工具 gradle](https://www.imooc.com/learn/833)
C
CyC2018 已提交
142