• Gradle基础知识-Wrapper,Daeman;Groovy闭包语法


    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
    }
    
    • 1
    • 2
    • 3

    等价于

    举例剖析:

        plugins( {
            id ('com.android.application'). version ('7.2.0'). apply( false)
        })
    
    • 1
    • 2
    • 3

    可以看到是调用plugins方法,这个方法的参数是一个闭包因此可以省略掉括号提取到外面;参数类型可以不用往()里面写,方法的调用也是通过空格分割开。

    PluginDependencySpec id(String var1); 调用id传入string返回PluginDependencySpec 类

    public interface PluginDependencySpec {

    PluginDependencySpec version(@Nullable String var1);

    PluginDependencySpec apply(boolean var1);

    }

    version返回的这个类又有两个方法再次调用,也就是上面说的:

    version “” apply false

  • 相关阅读:
    16.SpringBoot前后端分离项目之简要配置一
    穿透 wsl 和 ssh, 新版本 neovim 跨设备任意复制,copy anywhere!
    C++ 炼气期之变量的生命周期和作用域
    (181)Verilog HDL:设计一个计数器count_clock
    Spring5源码-FactoryBean介绍
    【历史上的今天】5 月 26 日:美国首个计算机软件程序专利;苹果市值首次超越微软;Wiki 的发明者出生
    [问题解决]解决编译时,Androidx和其他三方库冲突
    全局 id生成对比
    2022年软件测试经典面试真题
    wordpress redirected you too many times.(多重重定向)
  • 原文地址:https://blog.csdn.net/qq_45272690/article/details/126409868