天天看点

Gradle生命周期及其监听

前言

学习groovy的目的最终是为了更好的使用gradle,前面已经对groovy进行了一些列的学习,接下来开始gradle的学习

一、Gradle的执行流程

  1. Initialization初始化阶段
解析整个工程中的所有Project,构建所有的Project对应的project对象
  1. Configuration配置阶段
解析所有projects对象中的task,构建好所有task的拓扑图(有向无环图)
  1. Execution执行阶段
执行具体的task及其依赖的task
  • 我们都知道,在一个Android工程中可能有很多个Module,那么每一个Module都会对应着一个Project对象(后面也会讲到Gradle的关键API,Project)。
  • 新建一个项目,并且创建五个module,如下图

module结构.png

  • 那么就会在settings.gradle文件中将这些module include进来

settings.gradle.png

  • 初始化阶段,就会解析settings.gradle文件,生成对应的project对象
  • 在生成所有的project对象之后就会来到了配置阶段。一个Project包含很多个Task,即每个Project是由多个Task组成的。Task后面会讲到,现在先简单的理解为它就是一个原子性的操作,就像我们编程中的函数一样,每个Task都会完成自己的功能.下面是一个Task‘clean’,做Android的都应该见过它。作用也很简单,删除编译后产生的build目录
task clean(type: Delete) {
    delete rootProject.buildDir
}      
  • 在编程的时候,函数的调用是有一定顺序的,这个顺序当然是由我们决定的,比如java程序的运行,会先执行main函数,然后我们在main函数中执行自己的逻辑,调用其它方法,在方法中调用其它的方法。我们根据需求编写这些函数并让它们按照一定的的顺序正确执行,最终构建成整个拥有不同功能的应用。那么Gradle在构建APK的时候,也需要按照一定的顺序去执行一个一个的Task,最终构建出整个应用。那么这些Task之间,也有执行的先后顺序的,有些Task是依赖于其它Task的,需要再一些Task执行之后才执行(后面讲Task的时候会讲到如何利用Gradle提供的API决定Task之间的依赖关系),所以配置阶段就是去解析所有Project对象中的Task,构建好所有Task的拓扑图,即这些Task之间的执行顺序在配置阶段就确定了。
  • 在配置完成后,所有的Task的执行顺序已经确定了,那么就来到了执行阶段,执行具体的Task及其依赖Task。比如执行build Task,就会执行一系列build依赖的Task,再执行build Task本身,最终打包生成我们需要的APK。

二、Gradle生命周期的监听

  • 生命周期的回调监听方法
/**
 * 配置阶段开始前回调监听
 */
this.beforeEvaluate {
}

/**
 * 配置阶段完成后回调监听
 */
this.afterEvaluate {
    println '配置阶段完成...'
}

/**
 * gradle执行完毕的回调监听
 */
this.gradle.buildFinished {
    println 'gradle执行完毕...'
}      
  • 看过前面讲的Groovy内容再来看这个,应该很容易就看懂吧,没有看过的话,请先看看Groovy语法讲解内容。在core module的build.gradle文件中输入上面内容,然后在终端中输入gradlew clean,(mac中有点不同,./gradlew clean)执行一个比较简单的Task,也就是我们前面看到的clean Task,下面是输出结果

输出结果.png

  • 所以我们可以通过Gradle给我们提供的api监听它的生命周期过程,并且可以根据需求在不同的生命周期添加我们自己的逻辑。但是不知道大家注意没有,初始化阶段我并没有写出来,却也输出了,其实我是在settings.gradle中添加了这个输出语句,结果这句是最先输出的,这也就可以证明我们上面说的初始化阶段,其实也就是去解析settings.gradle。

初始化阶段.png

  • 当然还有其它的监听方法,比如beforProject,afterProject (等同配置阶段的监听)等等。还有下图的一些(相信大家看名字也能看懂)

生命周期监听方法.png

  • 其它监听
this.gradle.addBuildListener(new BuildListener() {
    @Override
    void buildStarted(Gradle gradle) {

    }

    @Override
    void settingsEvaluated(Settings settings) {

    }

    @Override
    void projectsLoaded(Gradle gradle) {

    }

    @Override
    void projectsEvaluated(Gradle gradle) {

    }

    @Override
    void buildFinished(BuildResult result) {

    }
})