學(xué)習(xí)Java
的同學(xué),相信你們都用過(guò)Maven
這個(gè)經(jīng)典實(shí)用的項(xiàng)目構(gòu)建工具。但是假如你經(jīng)常使用Maven
的話(huà),你或許會(huì)發(fā)現(xiàn)Maven
一些讓人不太舒服的地方:
- 一來(lái)
Maven
的配置文件是XML
格式的,假如你的項(xiàng)目依賴(lài)的包比較多,那么XML
文件就會(huì)變得非常非常長(zhǎng); - 二來(lái)
XML
文件不太靈活,假如你需要在構(gòu)建過(guò)程中添加一些自定義邏輯,搞起來(lái)非常麻煩; - 第三就是
Maven
非常的穩(wěn)定,但是相對(duì)的就是對(duì)新版java
支持不足,哪怕就是為了編譯java11
,也需要更新內(nèi)置的Maven
插件。
如果你對(duì)Maven
的這些缺點(diǎn)也有所感觸,準(zhǔn)備嘗試其他的構(gòu)建工具,那么你可以試試gradle
,這是一個(gè)全新的java
構(gòu)建工具,解決了Maven
的一些痛點(diǎn)。
安裝gradle
最傳統(tǒng)的安裝方法就是去gradle
官網(wǎng)下載二進(jìn)制包,解壓,然后將路徑添加到環(huán)境變量中。如果你沒(méi)什么其他需求,可以使用這種安裝方式。但是,gradle
是一個(gè)非常新潮的項(xiàng)目,每隔幾個(gè)月就會(huì)發(fā)布一個(gè)新版本,這種方式可能跟不上gradle
的更新速度。
所以我更加推薦使用包管理器來(lái)安裝gradle
。如果你使用linux
系統(tǒng),那么不必多說(shuō)。如果你使用Windows
系統(tǒng),我推薦使用scoop
包管理器來(lái)安裝gradle
。它安裝方便,而且使用SHIM
目錄來(lái)管理環(huán)境變量,在各種工具中配置gradle
也很方便。
當(dāng)然,如果你完全不喜歡安裝這么多亂七八糟的東西,那也可以使用gradle
。gradle
提供了一個(gè)名為gradle wrapper
的工具,可以在沒(méi)有安裝gradle
的情況下使用gradle
。好吧,其實(shí)它就是個(gè)腳本文件,當(dāng)你運(yùn)行wrapper
腳本的時(shí)候,如果腳本發(fā)現(xiàn)你電腦里沒(méi)有gradle
,就會(huì)自動(dòng)替你下載安裝一個(gè)。現(xiàn)在甚至還出現(xiàn)了Maven wrapper
,也是個(gè)腳本文件,可以自動(dòng)安裝Maven
。
之前相信一些朋友聽(tīng)說(shuō)過(guò)gradle
,然后嘗試使用它,結(jié)果因?yàn)樗俣忍?,最后放棄了。之前我也因?yàn)?code>gradle的速度,放棄了它一段時(shí)間。不過(guò)現(xiàn)在使用gradle
的話(huà)會(huì)方便很多。gradle
官方在中國(guó)開(kāi)設(shè)了CDN
,使用gradle wrapper
的時(shí)候下載速度非???。可以說(shuō)現(xiàn)在是一個(gè)學(xué)習(xí)使用gradle
的好時(shí)候。
使用gradle wrapper
這里我使用的IDEA
來(lái)創(chuàng)建和使用gradle
項(xiàng)目。
IDEA
默認(rèn)就會(huì)使用gradle wrapper
來(lái)創(chuàng)建項(xiàng)目,所以無(wú)需安裝gradle
也可以正常運(yùn)行。這時(shí)候項(xiàng)目結(jié)構(gòu)應(yīng)該類(lèi)似下圖所示,使用Maven
的同學(xué)應(yīng)該比較熟悉,因?yàn)檫@和Maven
的項(xiàng)目結(jié)構(gòu)幾乎完全一致。gradle
文件夾和gradlew
那幾個(gè)文件就是gradle wrapper
的文件,而.gradle
后綴名的文件正是gradle
的配置文件,對(duì)應(yīng)于Maven
的pom.xml
。
gradle wrapper
的優(yōu)點(diǎn)之一就是可以自定義下載的gradle
的版本,如果是團(tuán)隊(duì)協(xié)作的話(huà),這個(gè)功能就非常方便,簡(jiǎn)單設(shè)置即可統(tǒng)一團(tuán)隊(duì)的構(gòu)建工具版本。這里我就設(shè)定成目前最新的gradle 6.4
.默認(rèn)下載安裝的是bin
版,僅包含二進(jìn)制。如果你使用IDEA
的話(huà),它會(huì)推薦下載all
版,包含源代碼,這樣IDEA
就可以分析源代碼,提供更加精確的gradle
腳本支持。
依賴(lài)管理
下面來(lái)看看gradle
的依賴(lài)管理功能,這也算是我們使用構(gòu)建工具的主要目的之一了。這點(diǎn)也是gradle
相較maven
的優(yōu)勢(shì)之一了。相較于maven
一大串的XML
配置,gradle
的依賴(lài)項(xiàng)僅需一行。
dependencies {
testImplementation 'junit:junit:4.13'
implementation 'com.google.code.gson:gson:2.8.6'
}
這里推薦一下Jetbrains
的package search
網(wǎng)站,是尋找maven
和gradle
依賴(lài)包的最佳網(wǎng)站,可以非常輕松的搜索和使用依賴(lài)項(xiàng)。
(推薦教程:Java教程)
gradle
依賴(lài)的粒度控制相較于Maven
也更加精細(xì),maven
只有compile
、provided
、test
、runtime
四種scope
,而gradle
有以下幾種scope
:
- implementation,默認(rèn)的
scope
。implementation
的作用域會(huì)讓依賴(lài)在編譯和運(yùn)行時(shí)均包含在內(nèi),但是不會(huì)暴露在類(lèi)庫(kù)使用者的編譯時(shí)。舉例,如果我們的類(lèi)庫(kù)包含了gson
,那么其他人使用我們的類(lèi)庫(kù)時(shí),編譯時(shí)不會(huì)出現(xiàn)gson
的依賴(lài)。 - api,和
implementation
類(lèi)似,都是編譯和運(yùn)行時(shí)都可見(jiàn)的依賴(lài)。但是api
允許我們將自己類(lèi)庫(kù)的依賴(lài)暴露給我們類(lèi)庫(kù)的使用者。 - compileOnly和runtimeOnly,這兩種顧名思義,一種只在編譯時(shí)可見(jiàn),一種只在運(yùn)行時(shí)可見(jiàn)。而
runtimeOnly
和Maven
的provided
比較接近。 - testImplementation,這種依賴(lài)在測(cè)試編譯時(shí)和運(yùn)行時(shí)可見(jiàn),類(lèi)似于
Maven
的test
作用域。 - testCompileOnly和testRuntimeOnly,這兩種類(lèi)似于
compileOnly
和runtimeOnly
,但是作用于測(cè)試編譯時(shí)和運(yùn)行時(shí)。
通過(guò)簡(jiǎn)短精悍的依賴(lài)配置和多種多樣的作用與選擇,Gradle
可以為我們提供比Maven
更加優(yōu)秀的依賴(lài)管理功能。
gradle的任務(wù)和插件
gradle
的配置文件是一個(gè)groovy
腳本文件,在其中我們可以以編程方式自定義一些構(gòu)建任務(wù)。因?yàn)槭褂昧司幊谭绞?,所以這帶給了我們極大的靈活性和便捷性。打個(gè)比方,現(xiàn)在有個(gè)需求,要在打包出jar
的時(shí)候順便看看jar
文件的大小。在gradle
中僅需在構(gòu)建腳本中編寫(xiě)幾行代碼即可。而在Maven
中則需要編寫(xiě)Maven
插件,復(fù)雜程度完全不在一個(gè)水平。
當(dāng)然,Maven
發(fā)展到現(xiàn)在,已經(jīng)存在了大量的插件,提供了各式各樣的功能可以使用。但是在靈活性方面還是無(wú)法和Gradle
相比。而且Gradle
也有插件功能,現(xiàn)在發(fā)展也十分迅猛,存在了大量非常好用的插件,例如gretty
插件。gretty
原來(lái)是社區(qū)插件,后來(lái)被官方吸收為官方插件,可以在Tomcat
和jetty
服務(wù)器上運(yùn)行web
項(xiàng)目,比Maven
的相關(guān)插件功能都強(qiáng)大。
雖然gradle
可以非常靈活的編寫(xiě)自定義腳本任務(wù),但是其實(shí)一般情況下我們不需要編寫(xiě)構(gòu)建腳本,利用現(xiàn)有的插件和任務(wù)即可完成相關(guān)功能。在IDEA
里,也可以輕松的查看當(dāng)前gradle
項(xiàng)目中有多少任務(wù),基本任務(wù)如build
、test
等Maven
和Gradle
都是相通的。
配置鏡像
Maven
官方倉(cāng)庫(kù)的下載速度非常慢,所以一般我們要配置國(guó)內(nèi)的鏡像源。gradle
在這方面和Maven
完全兼容,因此只需稍微配置一下鏡像源,即可使用Maven
的鏡像。如果你用gradle
構(gòu)建過(guò)項(xiàng)目,應(yīng)該就可以在用戶(hù)目錄的.gradle
文件夾下看到gradle
的相關(guān)配置和緩存。
(推薦微課:Java微課)
之前wrapper
下載的gradle
也存放在該文件夾下,位置是wrapper/dists
。
而依賴(lài)的本地緩存在caches\modules-2\files-2.1
文件夾下。目錄結(jié)構(gòu)和Maven
的本地緩存類(lèi)似,都是包名+版本號(hào)的方式,但是gradle
的目錄結(jié)構(gòu)最后一層和Maven
不同,這導(dǎo)致它們無(wú)法共用本地緩存。
言歸正傳,在gradle
中配置下載鏡像需要在.gradle
文件夾中直接新建一個(gè)init.gradle
初始化腳本,腳本文件內(nèi)容如下。這樣一來(lái),gradle
下載鏡像的時(shí)候就會(huì)使用這里配置的鏡像源下載,速度會(huì)快很多。再加上gradle wrapper
在中國(guó)設(shè)置了CDN
,現(xiàn)在使用gradle
的速度應(yīng)該會(huì)很快。
allprojects {
repositories {
maven {
url "https://maven.aliyun.com/repository/public"
}
maven {
url "https://maven.aliyun.com/repository/jcenter"
}
maven {
url "https://maven.aliyun.com/repository/spring"
}
maven {
url "https://maven.aliyun.com/repository/spring-plugin"
}
maven {
url "https://maven.aliyun.com/repository/gradle-plugin"
}
maven {
url "https://maven.aliyun.com/repository/google"
}
maven {
url "https://maven.aliyun.com/repository/grails-core"
}
maven {
url "https://maven.aliyun.com/repository/apache-snapshots"
}
}
}
當(dāng)然,如果你有代理的話(huà),其實(shí)我推薦你直接為gradle
設(shè)置全局代理。因?yàn)?code>gradle腳本實(shí)在是太靈活了,有些腳本中可能依賴(lài)了github
或者其他地方的遠(yuǎn)程腳本。這時(shí)候上面設(shè)置的下載鏡像源就不管用了。
所以有條件還是干脆直接使用全局代理比較好。設(shè)置方式很簡(jiǎn)單,在.gradle
文件夾中新建gradle.properties
文件,內(nèi)容如下。中間幾行即是設(shè)置代理的配置項(xiàng)。當(dāng)然其他幾行我也建議你設(shè)置一下,把gradle
運(yùn)行時(shí)的文件編碼設(shè)置為UTF8
,增加跨平臺(tái)兼容性。
org.gradle.jvmargs=-Xmx4g -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8
systemProp.http.proxyHost=127.0.0.1
systemProp.http.proxyPort=10800
systemProp.https.proxyHost=127.0.0.1
systemProp.https.proxyPort=10800
systemProp.file.encoding=UTF-8
org.gradle.warning.mode=all
為什么使用gradle?
看到這里,你應(yīng)該對(duì)gradle
有了基本的了解, 也可以將其用于你的項(xiàng)目之中。但是如果你Maven
已經(jīng)非常熟悉了,可能不太愿意使用gradle
,因?yàn)槊菜茮](méi)有必要。但是既然gradle
出現(xiàn)了,就說(shuō)明有很多人對(duì)Maven
還是有一定的意見(jiàn)。因此在這里我來(lái)總結(jié)一下gradle
相比maven
的優(yōu)勢(shì)。
1.速度
gradle
使用構(gòu)建緩存、守護(hù)進(jìn)程等方式提高編譯速度。結(jié)果就是gradle
的編譯速度要遠(yuǎn)超maven
,平均編譯速度比Maven
快好幾倍,而且項(xiàng)目越大,這個(gè)差距就越明顯。
2.靈活性
gradle
要比Maven
靈活太多,雖然有時(shí)候靈活并不是一件好事情。但是大部分情況下,靈活一點(diǎn)可以極大的方便我們。Maven
死板的XML
文件方式做起事情來(lái)非常麻煩。很多Maven
項(xiàng)目都通過(guò)執(zhí)行外部腳本的方式來(lái)完成一些需要靈活性的工作。而在gradle
中配置文件就是構(gòu)建腳本,構(gòu)建腳本就是編程語(yǔ)言(groovy編程語(yǔ)言),完全可以自給自足,無(wú)需外部腳本。
3.簡(jiǎn)潔性
完成同樣的功能,gradle
腳本的長(zhǎng)度要遠(yuǎn)遠(yuǎn)短于maven
配置文件的長(zhǎng)度。雖然很多人都說(shuō)XML
維護(hù)起來(lái)不麻煩,但是我覺(jué)得,維護(hù)一個(gè)光是依賴(lài)就有幾百行的XML
文件,不見(jiàn)得就比gradle
腳本簡(jiǎn)單。
也許是因?yàn)槲疑厦嬲f(shuō)的原因,也許有其他原因,不得不承認(rèn)的一件事情就是gradle
作為一個(gè)新興的工具已經(jīng)有了廣泛的應(yīng)用。spring
等項(xiàng)目已經(jīng)從Maven
切換到了gradle
。開(kāi)發(fā)安卓程序也只支持gradle
了。因此不管是否現(xiàn)在需要將項(xiàng)目從maven
切換到gradle
,但是至少學(xué)習(xí)gradle
是一件必要的事情。
(推薦教程:Gradle 教程)
以上就是關(guān)于一款現(xiàn)代高效的 Java 構(gòu)建工具-- gradle 的優(yōu)點(diǎn)介紹了,希望對(duì)大家所有幫助。
作者:百樂(lè)川
文章來(lái)源:www.toutiao.com/i6824937779193971207