本篇文章参考资料:
1、https://docs.gradle.org/current/userguide/userguide.html
2、《Gradle In Action》
3、《Gradle for Android》
构建工具
一个可编程的工具,用来执行一系列有序的任务来表达自动化需求(编译源代码 -> 拷贝文件 -> 组装构建,当然这些任务不是固定的,可能还有其他任务)
熟悉Java开发的人员都知道,有几个流行的Java构建工具:Ant、Maven、Gradle。
Ant
Apache Ant(Apache Neat Tool)是一个用Java编写的开源构建工具。主要目的是在Java项目中为常用任务提供自动化,比如:编译源代码、运行单元测试、打包JAR文件、生成Javadoc文档等。虽然Ant的核心是Java编写的,但是build文件是通过XML表示的。
Maven
Apache Maven也是一个Java项目的构建工具,Maven要求Maven基于构建生命周期的思想,每个项目都确切的知道有哪些步骤去执行构建、打包、发布。和Ant不同Maven要求标准化的项目布局和统一构建生命周期。
Gradle
Gradle是新一代的构建工具,有几个重要特性:方便和其他构建工具集成、Groovy语言易接受方便扩展、API强大、构建脚本不像XML那样更容易阅读等等
Gradle构建简介
这里只是简单介绍,更详细的资料去(https://docs.gradle.org/current/userguide/userguide.html)这里看。
Gradle的几个核心类型(主要从Android项目的角度)
Project:表示需要构建的一个项目,类似Android项目的一个module,Project和build.gradle是一一对应的。Project提供了一套api用来查看工程信息。
Task:对一个项目的构建,就是对该项目中Task集合的运行,每个Task执行一些基本的工作,比如:编译、运行单元测试、压缩成apk等
build.gradle:构建脚本(相当于maven的pom.xml)
gradle.properties:属性文件,每个项目可以创建属性文件也可以不创建。
setting.gradle:声明所需的配置来实例化项目的层次结构(意思就类似编译整个大工程,需要包含哪些模块一起编译)
脚本的结构
构建脚本由若干语句和脚本块组成,以一个简单的Android项目为例说明(以下部分是从这里copy过来的(https://guides.gradle.org/building-android-apps/?_ga=2.120415560.152690407.1517379931-1154587000.1517379931))
创建一个新的Android Studio项目
下载并安装Android Studio后,启动应用程序。在欢迎界面中,点击标题为“开始一个新的Android Studio项目”的链接,如图所示。准备好后,单击下一步。
在“创建Android项目”屏幕上,将应用程序名称设置为“HelloWorldGradle”,将公司域设置为您自己的域(在附图中使用域gradle.org),并为项目位置选择任何方便的目录。然后点击下一步。
在“Target Android Devices”屏幕上,选择Phone and Tablet并从Minimum SDK下拉列表中选择任何最近的API级别。该图显示了API 19,这是常见的,但所选的值不会影响本指南的其余部分。
在“添加活动”屏幕上,选择清空活动并单击下一步。
接受“配置活动”屏幕上的所有默认设置,然后单击完成。
查看生成的Gradle文件列表
默认情况下,Android Studio将以“Android”模式下的“项目视图”开始,如下图所示:
Android项目是Gradle多项目构建,包含一个顶层build.gradle
文件和一个子目录app
,并带有自己的build.gradle
文件。顶层构建文件(Project: HelloWorldGradle)
如图所示,app
构建文件已(Module: app)
附加到该文件中。
可能有两个文件被调用gradle.properties
。一个是本地项目。另一个只有gradle.properties
在.gradle
主目录的子目录中有全局文件的同名文件才存在。
settings.gradle
Gradle使用该文件来配置多项目构建。它应该由一行代码组成:
include ':app'
这告诉Gradle app
子目录也是一个Gradle项目。如果在稍后的时间,您要通过可用的向导将Android库添加到此项目中,则会创建另一个项目子目录并将其添加到此文件中。
最后一个文件被调用gradle-wrapper.properties
,它配置了所谓的Gradle Wrapper。这使您可以构建Android项目,而无需首先安装Gradle。该文件的内容应该类似于:
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-4.1-all.zip
前四行表示当包装首次运行时,它将下载Gradle发行版并将其存储在主目录.gradle/wrapper/dists
中的目录中。
最后一行distributionUrl
是Gradle的下载地址。
查看顶层Gradle构建文件
该项目build.gradle
文件应该有类似的内容:
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
google()
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:3.0.1'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
google()
jcenter()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
Gradle为构建文件定义了一个特定于域的语言(DSL)。该buildscript
标签是DSL的一部分。它告诉Gradle构建需要的资源(第三方插件、依赖项等),并告诉Gradle在哪里找到它。在这种情况下,使用坐标语法“group:name:version”指定所需的插件,其中的组是com.android.tools.build
,名称是gradle
,版本是3.0.1
。
当Gradle第一次构建这个项目时,插件将被下载并缓存,所以这个任务只执行一次。
该allprojects
标签保存适用于顶层项目及其包含的任何子项目的配置细节。在这种情况下,该块指定任何所需的相关性都应当从以下网站下载google
,或jcenter
在公共Bintray Artifactory的仓库https://jcenter.bintray.com。
最后,构建文件包含一个称为的自定义(或临时)任务clean
。它使用内置的任务类型Delete
,并对其进行配置,该clean
任务将删除buildDir
的rootProject
。两者都是项目属性,其值默认build
为该应用程序驻留的项目中的目录。
检查应用程序模块中的构建文件
打开模块中的build.gradle
文件app
。第一行是:
apply plugin: 'com.android.application'
这个“插件”(buildscript
在顶级构建文件的部分中提到)应用到当前项目。Gradle中的插件可以将自定义任务,新配置,依赖关系和其他功能添加到Gradle项目中。在这种情况下,应用Android插件会添加各种各样的任务,这些任务由android
接下来显示的块配置。
android {
compileSdkVersion 26
defaultConfig {
applicationId "org.gradle.helloworldgradle"
minSdkVersion 19
targetSdkVersion 26
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
这些属性比Gradle构建系统更适合于Android,因此只能在这里对其进行简单的介绍。简而言之:
在
compileSdkVersion
与Android的SDK相关联,并应始终是最新版本。该
defaultConfig
部分拥有应用程序的所有变体(构建类型和产品风格的组合)共享的属性。这
applicationId
是基于创建应用程序时指定的域名和项目名称,并且在Google Play商店中必须是唯一的。其价值
minSdkVersion
是您愿意使用此应用程序支持的最低Android API,并且targetSdkVersion
应该是最新的Android版本。versionCode
在将新版本的应用上传到Google Play商店之前,值应该是递增的整数。这个值和applicationId
Google 一起告诉Google,这是一个现有应用程序的新版本,而不是一个新的应用程序。该
versionName
值用于您自己的内部版本跟踪。该
testInstrumentationRunner
属性被配置为使用为Android应用程序配置的JUnit 4测试运行器。
在这部分下面是一个叫做的块buildTypes
。默认情况下,Android应用程序支持两种构建类型,debug
而release
。这部分可以让你配置每个你喜欢的。这debug
部分没有在这里显示,这意味着debug
正在使用的所有默认设置。
在android
块之后,有一个块显示用于这个应用程序的库。
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'com.android.support:appcompat-v7:26.1.0'
implementation 'com.android.support.constraint:constraint-layout:1.0.2'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1'
}
配置依赖关系是构建Gradle应用程序的基础部分。在这种情况下,dependencies
部分显示的值implementation
,testImplementation
和androidTestImplementation
配置。
先取最简单的一个,testImplementation
依赖关系只包含最新的JUnit 4稳定版本。JUnit类和测试注释将在编译时在src/test/java
层次结构中可用。
该androidTestImplementation
依赖性是指咖啡的测试库,用于Android应用程序的集成测试。在这种情况下,Espresso在没有support-annotations
通常包含的库的情况下被请求,因为已经通过其他依赖包含了不同的版本。在后面的步骤中,您将看到如何找出该库的版本以及原因。
最后,有三条线将依赖关系添加到implementation
配置中:
第一个,
fileTree(dir: 'libs', include: ['*.jar'])
是一个fileTree
依赖,它将文件libs
夹中的所有jar文件添加到编译类路径中第二,
com.android.support:appcompat-v7:26.1.0
将Android兼容性库添加到项目中。这使您可以在SDK版本7以前的任何Android应用程序中使用材质设计主题和其他功能。第三,
com.android.support.constraint:constraint-layout:1.0.2
将Android约束布局添加到项目中。这允许您在任何像SDK版本9一样早的Android应用程序中使用ConstraintLayout布局类。