Skip to content

Latest commit

 

History

History
100 lines (61 loc) · 4.15 KB

File metadata and controls

100 lines (61 loc) · 4.15 KB

了解Gradle的整个构建生命周期之前我们需要先了解一下这些概念:

Gradle项目的组成

先来看一个常见的用Gradle构建的Android的项目(比如这个项目叫Search,主要包含一个搜索library和对library测试的Demo)

Search 
    --demo
        --src
        --build.gradle
    --library
        --src
        --build.gradle
    --build.gradle
    --setting.gradle

相信这个目录对大部分android工程师来说都是挺熟悉的。我们来大致看一下Gradle是如何理解这个目录组织的。

gradle中的工程

其实我们可以认为如果在一个目录下存在build.gradle文件,那么就可以认为这是一个gradle工程(即Project,工程名即目录的名字)。

build.gradle主要用于对工程进行配置。比如配置版本、依赖、使用的插件等等。

根工程与子工程

上面的Search项目有三个工程: Search、demo、library。从目录结构上看,demo、library好像是Search的子工程,但是如何在gradle中描述这种关系呢?

setting.gradle

setting.gradle文件是gradle用来初始化整个构建工程树的。默认情况下,如果不配置这个文件,只是在Search目录下执行构建,那么gradle是不会去构建demo和library这两个 项目的。只有在setting.gradle中配置了这两个工程,它们才算是Search的子工程。才会参与到Search项目的构建。如何配置呢?

如果demo和library项目的目录和settings.gralde是平级的,那么可以直接这样配置:

    include 'demo','library'

gradle会在当前根目录下查找 demolibrary文件夹,并认为他们是一个工程,将他们加入到构建工程树中。

include 'services:api'   -> gradle会去查找 services/api

如果demo和library项目的目录与settings.gradle不是平级,或者在其他的地方,那么就需要指定这两个工程的目录:

    include 'demo','library'
    project(':demo').projectDir = new File('dir path')

Task

举一个我们经常运行的命令 : gradle build

这里的build就是一个task,在gradle中task可以理解为一个操作,比如:打jar包、编译Java代码、上传jar包到maven。除了这些还有一些比较复杂的task,比如build,它就是由很多task组成的。 一个Project可以包含很多Task。

我们可以在一个工程根目录下运行gradle tasks查看,这个工程包含哪些task。

Gradle的整个构建生命周期

gradle的构建是在依赖分析完成后才开始的,简单来说就是你配置的所有依赖下载完毕后才会开始构建。在gradle中,整个构建分为3个过程:Initialization、Configuration、Execution。下面就针对这3个阶段简单看一下

Initialization

在初始化阶段,gradle要确定的一件比较重要的事是:这次构建是单工程构建还是多工程。即gradle会去寻找settings.grale文件。找的大致逻辑是:

  1. 当前目录查找settings.grale文件。查找到后开始构建
  2. 如果当前目录没有,则找当前目录的父目录有没有,如果有,则按照父目录的settings.grale开始构建
  3. 如果没有,则如果当前目录存在build.grale,进行单工程构建

确定好是单工程构建还是多工程构建后, 每一个参与构建的工程都会生成一个Project对象。

不过gradle这种查找settings.gradle来确定参与构建的工程的机制也存在一个问题:如果我们就是想构建这一个功能呢? 我们可以使用 -u 来使gradle不去查找settings.gradle

gradle -u build

Configuration

在确定了参与构建的工程后,在这个阶段会对每个工程的build.gralde进行逐行执行,会进行如下任务

  1. 加载插件
  2. 加载依赖
  3. 加载task
  4. 执行脚本,自定义的插件DSL代码,本身gradle支持的API等 ....

Execution

在这个阶段,gradle会根据参与构建的工程,创建这次任务执行的子任务,然后逐一执行这些任务。

关于gradle构建生命周期更细节的一些内容,可以参考官方文档 : https://docs.gradle.org/4.3/userguide/build_lifecycle.html