徹底搞懂Gradle、Gradle Wrapper與Android Plugin for Gradle的區別和聯系


歡迎和大家交流技術相關問題:
郵箱: jiangxinnju@163.com
博客園地址: http://www.cnblogs.com/jiangxinnju
GitHub地址: https://github.com/jiangxincode
知乎地址: https://www.zhihu.com/people/jiangxinnju

首先用一段通俗易懂但是不是非常專業的話描述一下三者的概念、區別和聯系。

  • Gradle是個構建系統,能夠簡化你的編譯、打包、測試過程。熟悉Java的同學,可以把Gradle類比成Maven。
  • Gradle Wrapper的作用是簡化Gradle本身的安裝、部署。不同版本的項目可能需要不同版本的Gradle,手工部署的話比較麻煩,而且可能產生沖突,所以需要Gradle Wrapper幫你搞定這些事情。Gradle Wrapper是Gradle項目的一部分。
  • Android Plugin for Gradle是一堆適合Android開發的Gradle插件的集合,主要由Google的Android團隊開發,Gradle不是Android的專屬構建系統,但是有了Android Plugin for Gradle的話,你會發現使用Gradle構建Android項目尤其的簡單。

另外需要說明的一點是Gradle、Gradle Wrapper與Android Plugin for Gradle不一定要和Android Studio一起使用,你可以完全脫離Android Studio,使用三者獨立進行Android項目的構建。下面是三者官方的指導文檔(從地址可以看出Gradle Wrapper是Gradle項目的一部分):

為了加深大家對於三者的理解,我們聊一聊在實際的項目構建中,這三者的關系,之前已經說過三者可以脫離Android Studio獨立使用,但是這種情況在實際開發場景中並不多見,所以本文還是使用Android Studio作為開發工具進行介紹。當我們新建一個Android項目時,會出現類似於下圖所示的目錄結構:

可以看到一個gradle/wrapper目錄,其中有兩個文件:gradle-wrapper.jar/gradle-wrapper.properties,gradle-wrapper.jar是Gradle Wrapper的主體功能包。在Android Studio安裝過程中產生gradle-wrapper.jar(如果默認安裝的話會在C:\Program Files\Android\Android Studio\plugins\android\lib\templates\gradle\wrapper\gradle\wrapper\gradle-wrapper.jar)。然后每次新建項目,會將gradle-wrapper.jar拷貝到你的項目的gradle/wrapper目錄中。gradle-wrapper.properties文件主要指定了該項目需要什么版本的Gradle,從哪里下載該版本的Gradle,下載下來放到哪里,如下圖所示:

其中GRADLE_USER_HOME一般指~/.gradle,從圖示項目中可以知道我要使用gradle-4.1版本,從https://services.gradle.org/distributions/gradle-4.1-all.zip下載,下載到本地的~/.gradle/wrapper/dists目錄。那是不是各個項目的Gradle都要通過Gradle Wrapper下載,能不能所有的項目共用一個Gradle?這樣理論上是可以的,但是由於Gradle本身不一定保持完全的兼容性,所以新老項目共用一個Gradle有時可能會遇到意想不到的問題。指定對應版本的Gradle,而不通過Gradle Wrapper下載的設置方式是勾選如下圖中的Use local gradle distribution,同時指定Gradle home:

Gradle對應版本下載完成之后,Gradle Wrapper的使命基本完成了,Gradle會讀取build.gradle文件,該文件中指定了該項目需要的Android Plugin for Gradle版本是什么,從哪里下載該版本的Android Plugin for Gradle。如下圖所示:

從圖示項目中可以知道我們要使用3.0.1版本,從google和jcenter處下載,那么下載到我們本地的哪里呢?它會下載到~\.gradle\caches\modules-2\files-2.1\com.android.tools.build中。有時候大家網絡裝填不好,選擇下圖中的Offline work時可能出現"No cached version of com.android.tools.build:gradle:xxx available for offline mode"問題,此時你只要將對應版本的Android Plugin for Gradle下載到本地的C:\Program Files\Android\Android Studio\gradle\m2repository\com\android\tools\build中即可。

好了,三者的關系從樣例項目中理清楚了。如果大家有什么疑問可以給我留言。

我的博客即將搬運同步至騰訊雲+社區,邀請大家一同入駐:https://cloud.tencent.com/developer/support-plan


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM