您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“Java構建工具gradle怎么安裝使用”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Java構建工具gradle怎么安裝使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
學習Java
的同學,相信你們都用過Maven
這個經典實用的項目構建工具。但是假如你經常使用Maven
的話,你或許會發現Maven
一些讓人不太舒服的地方:
一來Maven
的配置文件是XML
格式的,假如你的項目依賴的包比較多,那么XML
文件就會變得非常非常長;
二來XML
文件不太靈活,假如你需要在構建過程中添加一些自定義邏輯,搞起來非常麻煩;
第三就是Maven
非常的穩定,但是相對的就是對新版java
支持不足,哪怕就是為了編譯java11
,也需要更新內置的Maven
插件。
如果你對Maven
的這些缺點也有所感觸,準備嘗試其他的構建工具,那么你可以試試gradle
,這是一個全新的java
構建工具,解決了Maven
的一些痛點。
最傳統的安裝方法就是去gradle
官網下載二進制包,解壓,然后將路徑添加到環境變量中。如果你沒什么其他需求,可以使用這種安裝方式。但是,gradle
是一個非常新潮的項目,每隔幾個月就會發布一個新版本,這種方式可能跟不上gradle
的更新速度。
所以我更加推薦使用包管理器來安裝gradle
。如果你使用linux
系統,那么不必多說。如果你使用Windows
系統,我推薦使用scoop
包管理器來安裝gradle
。它安裝方便,而且使用SHIM
目錄來管理環境變量,在各種工具中配置gradle
也很方便。
當然,如果你完全不喜歡安裝這么多亂七八糟的東西,那也可以使用gradle
。gradle
提供了一個名為gradle wrapper
的工具,可以在沒有安裝gradle
的情況下使用gradle
。好吧,其實它就是個腳本文件,當你運行wrapper
腳本的時候,如果腳本發現你電腦里沒有gradle
,就會自動替你下載安裝一個。現在甚至還出現了Maven wrapper
,也是個腳本文件,可以自動安裝Maven
。
之前相信一些朋友聽說過gradle
,然后嘗試使用它,結果因為速度太慢,最后放棄了。之前我也因為gradle
的速度,放棄了它一段時間。不過現在使用gradle
的話會方便很多。gradle
官方在中國開設了CDN
,使用gradle wrapper
的時候下載速度非常快。可以說現在是一個學習使用gradle
的好時候。
這里我使用的IDEA
來創建和使用gradle
項目。
IDEA
默認就會使用gradle wrapper
來創建項目,所以無需安裝gradle
也可以正常運行。這時候項目結構應該類似下圖所示,使用Maven
的同學應該比較熟悉,因為這和Maven
的項目結構幾乎完全一致。gradle
文件夾和gradlew
那幾個文件就是gradle wrapper
的文件,而.gradle
后綴名的文件正是gradle
的配置文件,對應于Maven
的pom.xml
。
gradle wrapper
的優點之一就是可以自定義下載的gradle
的版本,如果是團隊協作的話,這個功能就非常方便,簡單設置即可統一團隊的構建工具版本。這里我就設定成目前最新的gradle 6.4
.默認下載安裝的是bin
版,僅包含二進制。如果你使用IDEA
的話,它會推薦下載all
版,包含源代碼,這樣IDEA
就可以分析源代碼,提供更加精確的gradle
腳本支持。
下面來看看gradle
的依賴管理功能,這也算是我們使用構建工具的主要目的之一了。這點也是gradle
相較maven
的優勢之一了。相較于maven
一大串的XML
配置,gradle
的依賴項僅需一行。
dependencies { testImplementation 'junit:junit:4.13' implementation 'com.google.code.gson:gson:2.8.6' }
這里推薦一下Jetbrains
的package search
網站,是尋找maven
和gradle
依賴包的最佳網站,可以非常輕松的搜索和使用依賴項。
gradle
依賴的粒度控制相較于Maven
也更加精細,maven
只有compile
、provided
、test
、runtime
四種scope
,而gradle
有以下幾種scope
:
implementation,默認的scope
。implementation
的作用域會讓依賴在編譯和運行時均包含在內,但是不會暴露在類庫使用者的編譯時。舉例,如果我們的類庫包含了gson
,那么其他人使用我們的類庫時,編譯時不會出現gson
的依賴。
api,和implementation
類似,都是編譯和運行時都可見的依賴。但是api
允許我們將自己類庫的依賴暴露給我們類庫的使用者。
compileOnly和runtimeOnly,這兩種顧名思義,一種只在編譯時可見,一種只在運行時可見。而runtimeOnly
和Maven
的provided
比較接近。
testImplementation,這種依賴在測試編譯時和運行時可見,類似于Maven
的test
作用域。
testCompileOnly和testRuntimeOnly,這兩種類似于compileOnly
和runtimeOnly
,但是作用于測試編譯時和運行時。
通過簡短精悍的依賴配置和多種多樣的作用與選擇,Gradle
可以為我們提供比Maven
更加優秀的依賴管理功能。
gradle
的配置文件是一個groovy
腳本文件,在其中我們可以以編程方式自定義一些構建任務。因為使用了編程方式,所以這帶給了我們極大的靈活性和便捷性。打個比方,現在有個需求,要在打包出jar
的時候順便看看jar
文件的大小。在gradle
中僅需在構建腳本中編寫幾行代碼即可。而在Maven
中則需要編寫Maven
插件,復雜程度完全不在一個水平。
當然,Maven
發展到現在,已經存在了大量的插件,提供了各式各樣的功能可以使用。但是在靈活性方面還是無法和Gradle
相比。而且Gradle
也有插件功能,現在發展也十分迅猛,存在了大量非常好用的插件,例如gretty
插件。gretty
原來是社區插件,后來被官方吸收為官方插件,可以在Tomcat
和jetty
服務器上運行web
項目,比Maven
的相關插件功能都強大。
雖然gradle
可以非常靈活的編寫自定義腳本任務,但是其實一般情況下我們不需要編寫構建腳本,利用現有的插件和任務即可完成相關功能。在IDEA
里,也可以輕松的查看當前gradle
項目中有多少任務,基本任務如build
、test
等Maven
和Gradle
都是相通的。
Maven
官方倉庫的下載速度非常慢,所以一般我們要配置國內的鏡像源。gradle
在這方面和Maven
完全兼容,因此只需稍微配置一下鏡像源,即可使用Maven
的鏡像。如果你用gradle
構建過項目,應該就可以在用戶目錄的.gradle
文件夾下看到gradle
的相關配置和緩存。
之前wrapper
下載的gradle
也存放在該文件夾下,位置是wrapper/dists
。
而依賴的本地緩存在caches\modules-2\files-2.1
文件夾下。目錄結構和Maven
的本地緩存類似,都是包名+版本號的方式,但是gradle
的目錄結構最后一層和Maven
不同,這導致它們無法共用本地緩存。
言歸正傳,在gradle
中配置下載鏡像需要在.gradle
文件夾中直接新建一個init.gradle
初始化腳本,腳本文件內容如下。這樣一來,gradle
下載鏡像的時候就會使用這里配置的鏡像源下載,速度會快很多。再加上gradle wrapper
在中國設置了CDN
,現在使用gradle
的速度應該會很快。
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" } } }
當然,如果你有代理的話,其實我推薦你直接為gradle
設置全局代理。因為gradle
腳本實在是太靈活了,有些腳本中可能依賴了github
或者其他地方的遠程腳本。這時候上面設置的下載鏡像源就不管用了。
所以有條件還是干脆直接使用全局代理比較好。設置方式很簡單,在.gradle
文件夾中新建gradle.properties
文件,內容如下。中間幾行即是設置代理的配置項。當然其他幾行我也建議你設置一下,把gradle
運行時的文件編碼設置為UTF8
,增加跨平臺兼容性。
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
有了基本的了解, 也可以將其用于你的項目之中。但是如果你Maven
已經非常熟悉了,可能不太愿意使用gradle
,因為貌似沒有必要。但是既然gradle
出現了,就說明有很多人對Maven
還是有一定的意見。因此在這里我來總結一下gradle
相比maven
的優勢。
gradle
使用構建緩存、守護進程等方式提高編譯速度。結果就是gradle
的編譯速度要遠超maven
,平均編譯速度比Maven
快好幾倍,而且項目越大,這個差距就越明顯。
gradle
要比Maven
靈活太多,雖然有時候靈活并不是一件好事情。但是大部分情況下,靈活一點可以極大的方便我們。Maven
死板的XML
文件方式做起事情來非常麻煩。很多Maven
項目都通過執行外部腳本的方式來完成一些需要靈活性的工作。而在gradle
中配置文件就是構建腳本,構建腳本就是編程語言(groovy編程語言),完全可以自給自足,無需外部腳本。
完成同樣的功能,gradle
腳本的長度要遠遠短于maven
配置文件的長度。雖然很多人都說XML
維護起來不麻煩,但是我覺得,維護一個光是依賴就有幾百行的XML
文件,不見得就比gradle
腳本簡單。
也許是因為我上面說的原因,也許有其他原因,不得不承認的一件事情就是gradle
作為一個新興的工具已經有了廣泛的應用。spring
等項目已經從Maven
切換到了gradle
。開發安卓程序也只支持gradle
了。因此不管是否現在需要將項目從maven
切換到gradle
,但是至少學習gradle
是一件必要的事情。
讀到這里,這篇“Java構建工具gradle怎么安裝使用”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。