安装步骤
第一步:
从网站上下载 Gradle
第二部:
部署环境变量
检查是否安装成功:
gradle -v
由上图我们可以看到gradle对应的版本信息,至此环境搭建已经完成。
Gradle的语法
简介
Gradle构建脚本文件用来处理两件事情:一个是项目和另一个的任务。每个Gradle
生成表示一个或多个项目。一个项目表示一个JAR库或Web应用程序,也可能表示由其他项目产生的JAR文件组装的ZIP。 简单地说,一个项目是由不同的任务组成。一个任务是指构建执行的一块工作。任务可能是编译一些类,创建一个JAR,产生的Javadoc或发布一些归档文件库。Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化建构工具。它使用一种基于Groovy的特定领域语言(DSL)来声明项目设置,抛弃了基于XML的各种繁琐配置。 面向Java应用为主。当前其支持的语言限于Java、Groovy和Scala,计划未来将支持更多的语言。
编写构建脚本
Gradle提供了一个域特定语言(DSL),用于描述构建。 它使用 Groovy 语言,使其更容易来形容和构建。Gradle 中的每一个构建脚本使用UTF-8进行编码保存,并命名为 build.gradle 。
创建对应的build.gradle文件,并且编写对应的helloword任务
task helloworld << {
println 'holle world !'
}
在dos环境下执行命令:
gradle -q helloworld
由此我们可以得到执行gradle脚本的命令语法:
gradle -q <taskName>
gradle如何使用groovy API
首先,我们看一个将字符串转化成大写的API方法:
task uper << {
String inputStr = "hello world !"
println "初始化字符串的值:"+inputStr
println "转化成大写之后的字符串的值:"+inputStr.toUpperCase()
}
执行任务:
gradle -q uper
结果:
隐式参数 $it 的使用:
task count << {
4.times{
print "$it"
}
println ''
}
time类似于迭代器,而$it表示迭代项。
执行上面的任务:
gradle -q count
上面代码中$it引用必须使用双引号扩起来,否则会当做字符串打印传来,如下所示:
使用双引号正常输出:
groovy 的jdk方法
- each()方法
task groovyJdkMethod{
String myName = 'lenyan_zhao'
myName.each(){
println "$it"
}
}
执行任务:
gradle -q groovyJdkMethod
结果:
由此看出each方法迭代器方式实现字符串字符的迭代处理。
Task依赖
多个任务之间存在依赖关系,同设置参数dependsOn:<taskName>来指定当前任务的依赖任务:
//任务的依赖
task info (dependsOn:helloworld)<<{
println 'lenyan_zhao'
}
info任务依赖于helloworld任务,看执行结果:
由结果可知,依赖关系先执行被依赖项,后执行当前任务,当然这是比较正常的一种依赖关系,还有其他非正常的依赖关系,可以参考另一篇文章Gradle项目构建工具--快捷方式doLast以及乱码问题;
Task属性
- 以任务名称作为属性查看任务名称
task hello
println hello.name
println project.hello.name
执行结果:
- 以任务集合的方式查看任务的名称
task hello
println hello.name
println project.hello.name
println tasks["hello"].name
println project.tasks["hello"].name
添加依赖关系
要将一个任务依赖于另一个任务,这意味着当一个任务完成时,另一个任务将开始。 每个任务都使用任务名称进行区分。 任务名称集合由其任务集合引用。 要引用另一个项目中的任务,应该使用项目路径作为相应任务名称的前缀。
- 静态依赖关系
task t1 << {
println 't1'
}
task t2(dependsOn:'t1') << {
println 't2'
}
gradle -q t2
执行结果:
- 动态添加依赖关系
task t3 << {
println 't3'
}
task t4 << {
println 't4'
}
t4.dependsOn t3
执行结果:
- 闭包方式批量添加依赖
这种方式可以通过模糊匹配任务名称的方式进行批量添加对应的依赖任务:
//闭包批量添加依赖
task t5 << {
println 't5'
}
t5.dependsOn{
tasks.findAll{
//模糊匹配前缀是以lib开头的任务
task -> task.name.startsWith('lib')
}
}
task lib1 << {
println 'lib1'
}
task lib2 << {
println 'lib2'
}
task lib3 << {
println 'lib3'
}
task lib4 << {
println 'lib4'
}
执行任务t5,执行结果:
添加任务属性
//添加任务属性
task copy(type:Copy){
println 'start copy .'
description "Copies the resource directory to the target directory."
from "resources"
into "target"
include ('**/*.txt','**/*.xml','**/*.properties')
println "description applied"
}
description : 表示任务的描述属性
from : 资源文件的来源属性
into : 资源文件复制到目标文件夹配置属性
include : 配置复制文件的类型
执行结果:
注:此处代码如果任务添加快捷方式,执行任务时,不会输出任何信息
跳过任务
如果用于跳过任务的逻辑不能用谓词表示,则可以使用StopExecutionException。 如果操作抛出此异常,则会跳过此操作的进一步执行以及此任务的任何后续操作的执行。 构建继续执行下一个任务。
//跳过任务
task complie << {
println 'We are doing the complie'
}
complie.doFirst{
if(true){
throw new StopExecutionException()
}
}
task myTask(dependsOn:'complie') << {
println 'I\'m not affected'
}
执行结果:
本篇文章只是简单的介绍了Gradle基本操作语法以及window环境搭建流程,后续将会慢慢跟进对应的其他内容。