gradle descirbe:
gradle本质就是一个bin脚本,分为window和unix。
启动gradle:启动jvm加载lib所需的库
gradle wrapper
输入gradle wrapper命令会在当前目录创建安装一个jar包(用于下载真正的gradle descirbe,jar很小)和脚本:
gradle wrapper命令(简称gradlew,每个gradlew都和一个具体的gardle版本绑定)会 启动一个很小的jvm,加载gradlewrapper.jar判断当前文件夹是否存在对应版本的gradle如果没有则去下载对应版本的gradle(gradle的bin包)
gradleUserHome
缓存不同版本的Gradle的缓存文件
gradle doman:
Maven构建流程:
启动JVM然后执行加载jar包任务执行完任务完之后就销毁掉,下次再次构建的话还是一样的流程,由于JVM被销毁掉了,需要重新加载启动JVM然后重新加载jar包。所以速度很慢
gradle构建的做法:
启动一个client 的JVM(很小,因为只是做一个请求中转接受数据结果操作)然后client启动一个daemon JVM,DomanJVM加载jar包然后接受client JVM的请求做处理,处理完成后告知client JVM结果及日志; 当执行完成之后clie ntJVM 会被销毁。
下次执行构建的时候只需创建client JVM和damon JVM通信就行 由于但是daemon不会销毁,其中会缓存上次加载过的jar,有了缓存自然速度会快。每次构建的时候相比maven的冷启动,gradle的热启动会快很多,doamen三个小时没有接受请求会自动退出。默认这个doman会开启,但是daemon并不是所有时候都会开启(需要兼容client JVM ,当不匹配时client会启动一个新的daemon)。
构建的时候可以指定--no-daemon参数,那么这个daemon每次构建完就会和maven一样销毁。(gradle3.0之前需要使用这个参数,现在已经很稳定了不需要这个参数了)
daemon进程
通过命令查看启动的daemon进程 : gradle --status查找运行的daemon进程
INFO是gradle的版本号
Daemon什么时候会失效需要重新启动:
- 修改 JVM 配置这回造成启动新的构建进程
- Gradle 将杀死任何闲置了3小时或更长时间的守护程序
- 一些环境变量的变化,如语言、keystore、keyStorePassword、keyStoreType 这些变化都会造成旧有的守护进程失效
完整流程:
- 使用gradlew 启动一个gradle Task:启动一个轻量JVM。查找是否安装有对应版本的gradle,如果没有就启动wrapper进程先去下载(会下载到gradle userhome中),有就是下一步
- 查找gradle对应版本并且和当前构建所要求的相关的参数所兼容的daemon JVM进程,如果没有找到就启动daemon JVM,如果找到就连接(使用socket)daemon
gradle daemon stared:第一次启动daemon
- 将当前任务和所需的上下文(当前环境变量等)给到daemon执行
groovy语法介绍
运行在JVM上的脚本语言,强类型动态调用的
动态调用
默认Goovy是动态调用,如果加上@CommonStatic注解的话那么这段代码会像java一样进行静态编译并进行静态检查
构造方法及方法调用
Groovy的类会对其内部的所有全局变量生成一个map注入到构造方法中。
例如A类有一个a全局变量,创建A类的时候可以这样写 new A([a:1]),【】可以省略掉,new A(a:1)
java方法的调用字节码是invokednamic,但是Groovy调用方法是通过MOP反射:创建出对象后调用invokeMethod调用
闭包
闭包是groovy的核心。
最后一个语句是返回值,使用{}内部来定义方法。
声明闭包:def closure={it+1} 闭包就可以理解为方法,闭包可作为参数传递
it是默认参数如果指定参数名称就需要加上一句param->
调用闭包:print(closure(2)),和普通方法调用一样(可以将括号省略掉:方法名 空格 参数调用闭包);闭包是最后一个参数时,可以不在括号里面提取到外面
举例剖析:
plugins {
id 'com.android.application' version '7.2.0' apply false
}
等价于
举例剖析:
plugins( {
id ('com.android.application'). version ('7.2.0'). apply( false)
})
可以看到是调用plugins方法,这个方法的参数是一个闭包因此可以省略掉括号提取到外面;参数类型可以不用往()里面写,方法的调用也是通过空格分割开。
PluginDependencySpec id(String var1); 调用id传入string返回PluginDependencySpec 类
public interface PluginDependencySpec {PluginDependencySpec version(@Nullable String var1);
PluginDependencySpec apply(boolean var1);
}
version返回的这个类又有两个方法再次调用,也就是上面说的:
version "" apply false