工具篇 | Gradle入门与使用指南 - 附Github仓库地址

介绍

1.1 什么是Gradle?

Gradle是一个开源构建自动化工具,专为大型项目设计。它基于DSL(领域特定语言)编写,该语言是用Groovy编写的,使得构建脚本更加简洁和强大。Gradle不仅可以构建Java应用程序,还支持多种语言和技术,例如C++、Python、Android等。
更多信息和详细文档可以在Gradle官方网站上找到。

1.2 为什么选择Gradle?

与其他流行的构建工具(如Maven和Ant)相比,Gradle提供了以下优势:

  • 性能:Gradle使用它的守护程序和增量构建技术来提高构建速度。你可以在1查看Gradle与其他工具的性能对比图。
    在这里插入图片描述

  • 灵活性:Gradle的DSL使你可以编写高度定制化的构建脚本。

  • 可扩展性:Gradle可以通过插件机制轻松扩展,有着丰富的插件生态系统。

  • Android官方支持:对于Android开发,Google官方推荐使用Gradle作为构建工具。


安装和设置

2.1 前提条件

在安装Gradle之前,你需要确保满足以下前提条件:

  • 一个有效的Java Development Kit (JDK)安装。Gradle 7.0及以上版本需要JDK版本为8到16。
  • JAVA_HOME 环境变量已正确设置,指向JDK的安装目录。

2.2 下载和安装Gradle

  1. 直接下载:你可以从Gradle官方下载页面下载最新版本的Gradle分发包。选择合适的分发包,通常我们使用二进制分发包。

  2. 使用包管理器:对于某些操作系统,如macOS,你可以使用Homebrew包管理器来安装:

    brew install gradle
    

    对于Linux用户,可以使用SDKMAN:

    sdk install gradle
    
  3. 解压下载的文件到一个合适的安装位置。

  4. 将解压后的路径添加到你的操作系统的PATH变量中,以便从任何位置运行Gradle命令。

2.3 验证安装

要验证你的Gradle安装是否成功,可以在命令行或终端中运行以下命令:

gradle -v

会显示Gradle的版本、Groovy的版本以及JVM版本等详细信息,如下图所示:
在这里插入图片描述


Gradle基础概念

3.1 项目和任务

在Gradle中,构建是由项目任务组成的。

  • 项目:代表你正在构建的东西,可以是一个库、应用程序或者是一个更大的单元,如多模块项目。一个构建可以有一个或多个项目。
  • 任务:表示一个原子的构建操作,例如编译类或创建JAR文件。

3.2 构建脚本

Gradle使用构建脚本来配置和控制构建过程。这些脚本默认使用GroovyKotlin DSL编写,并具有特定的文件名,如build.gradlebuild.gradle.kts
构建脚本定义了项目和任务以及它们之间的关系。

3.3 依赖管理

Gradle不仅仅是一个构建工具,它还有一个强大的依赖管理系统,允许你声明你的项目依赖的外部库,并自动下载和管理它们。

3.4 插件

插件扩展了Gradle的功能,使得常见的构建任务和配置变得简单。例如,Java插件为Java项目添加了常见的任务,如编译和打包。
使用插件通常是通过在构建脚本中声明它们来完成的。例如:

plugins {id 'java'
}

3.5 生命周期

Gradle任务有一个生命周期,包括三个阶段:

  1. 初始化:在此阶段,Gradle决定要处理哪些项目。
  2. 配置:在此阶段,Gradle构建所有的项目的任务对象。
  3. 执行:在此阶段,Gradle运行实际的任务。

创建和运行你的第一个Gradle项目

4.1 初始化项目

你可以使用Gradle的命令行界面创建一个新的项目。例如,要创建一个新的Java应用程序,可以运行以下命令:

gradle init --type java-application

指定一些版本号,就会在当前目录下生成一个新的Java项目。
在这里插入图片描述

4.2 项目结构

上面的命令执行完毕后,会在目录下创建这样的一个结构:
在这里插入图片描述

4.3 编写代码

它默认会在app/src/main/java目录中添加一个简单的App类。

public class App {public String getGreeting() {return "Hello World!";}public static void main(String[] args) {System.out.println(new App().getGreeting());}
}

4.4 构建项目

在项目的根目录中,运行以下命令来构建项目:

gradle build

这会编译Java类、运行任何测试(如果有的话)并创建一个JAR文件。
在这里插入图片描述

4.5 运行应用

如果你已经使用--type java-application来初始化项目,你可以使用以下命令来运行你的应用:

gradle run

你应该会看到Hello World!的输出。
在这里插入图片描述


Gradle构建脚本基础

5.1 build.gradle文件的作用

build.gradle是Gradle构建的核心。它是一个用Groovy或Kotlin DSL编写的脚本,用于定义项目的构建逻辑。它描述了如何编译和打包代码,如何运行测试,以及如何发布成果物。

5.2 任务(Tasks)

任务是构建的原子操作。每个任务都代表了构建过程中的一个步骤。例如,编译源代码、运行单元测试、生成文档等。

tasks.register('myTask') {doLast {println 'This is a custom task.'}
}

上面的代码定义了一个名为myTask的任务,当其被执行时,会在控制台上打印出消息。我们把这段话复制到刚刚的build.gradle下,然后执行就会打印这句话:
在这里插入图片描述

5.3 依赖(Dependencies)

任务之间可能存在依赖关系。这意味着一个任务可能依赖于其他一个或多个任务的成功执行。

tasks.register('taskA') {doLast {println 'Task A is executed.'}
}tasks.register('taskB') {dependsOn 'taskA'doLast {println 'Task B is executed.'}
}

在上面的例子中,taskB依赖于taskA。当你执行taskB时,首先会执行taskA。如图所示:
在这里插入图片描述

5.4 插件(Plugins)

插件是一种强大的扩展Gradle功能的方式。它们可以提供额外的构建任务,增强现有任务,甚至改变Gradle的核心行为。下面列举了一些常用的插件和它们的作用。

plugins {id 'java' // Java插件,为Java项目提供编译、测试和打包的任务id 'application' // Application插件,可以创建可运行的应用程序,提供了‘run’任务来运行应用id 'war' // War插件,用于构建Java Web应用程序,提供了生成WAR文件的任务
}

Java插件

java插件是最基础的插件之一,提供了用于Java项目的核心任务,如compileJava来编译Java源代码和test来运行测试。

Application插件

application插件扩展了java插件,提供了创建可执行Java应用程序所需的功能。最重要的是,它添加了run任务,允许你直接从Gradle运行你的应用。

War插件

war插件是为Java Web应用程序设计的,用于生成WAR文件,这是Java EE和Servlet容器通常使用的部署格式。

其他插件

Gradle拥有丰富的插件生态系统,包括但不限于Android开发、Spring Boot集成、Docker构建等。你可以浏览Gradle Plugin Portal来查找更多可用的插件。
每个插件都有其独特的配置和用法,因此在使用新插件时,请务必查阅其官方文档,以了解如何正确配置和使用它们。
不同的插件解决了不同的问题,但它们都遵循着同样的设计原则和配置方式,一旦你熟悉了几个常用插件的用法,就能快速学会使用新的插件。


常用的Gradle任务

在Gradle中,每一个构建动作都是通过执行一个或多个任务来完成的。当我们引入插件时,这些插件通常会为我们预定义一些任务。以下,我们将深入探讨一些常用的Gradle任务。

6.1 清理

任务名称: clean
这是一个非常常用的任务。当执行此任务时,Gradle会删除构建目录,确保下一次构建是从干净的状态开始的。
使用命令:

gradle clean

6.2 构建

任务名称: build
此任务是Java插件提供的。当执行此任务时,Gradle会执行完整的构建周期,包括编译、测试等。
使用命令:

gradle build

6.3 测试

任务名称: test
该任务也是Java插件提供的。它负责运行项目的单元测试。
使用命令:

gradle test

6.4 运行

任务名称: run
为了使用此任务,我们需要引入application插件,并设置主类。

plugins {id 'application'
}
mainClassName = 'com.example.Main'

然后,可以使用以下命令来运行应用:

gradle run

依赖管理

在大多数软件项目中,我们通常依赖于第三方库来完成某些功能。Gradle提供了一个强大的依赖管理系统,使得声明、解析和使用这些第三方库变得轻而易举。

7.1 声明仓库

要使用外部依赖,首先需要告诉Gradle从哪里获取它们。最常用的仓库是Maven Central和JCenter。
例如,要添加Maven Central仓库,你可以这样写:

repositories {mavenCentral()
}

如果你想使用JCenter仓库:

repositories {jcenter()
}

7.2 声明和使用依赖

一旦设置了仓库,就可以开始添加依赖了。
例如,要在Java项目中使用Google的Gson库,可以如下添加:

dependencies {implementation 'com.google.code.gson:gson:2.8.6'
}

其中,implementation表示这是一个主要的运行时依赖。

7.3 依赖冲突解决

有时,当你的项目依赖于多个库,并且这些库依赖于相同库的不同版本时,就会发生冲突。Gradle有强大的冲突解决策略,通常会选择最新的版本。
但如果你需要更精确的控制,可以这样做:

configurations.all {resolutionStrategy {force 'com.google.code.gson:gson:2.8.5'}
}

这将确保项目中使用的Gson库版本为2.8.5,即使其他依赖可能请求了一个不同的版本。


使用插件

Gradle插件为构建和管理项目提供了额外的功能。从Java到Android,再到Spring Boot,几乎所有的现代框架和平台都有自己的Gradle插件来简化相关任务。

8.1 常见的插件

  • Java 插件: 这是最常用的插件之一,它为Java项目提供了编译、测试和打包的功能。

    plugins {id 'java'
    }
    
  • Application 插件: 如果你正在构建一个应用程序,这个插件可以帮助你打包并运行它。

    plugins {id 'application'
    }
    
  • War 插件: 为Web应用程序提供支持,使你能够构建WAR文件。

    plugins {id 'war'
    }
    

8.2 如何应用插件

你已经看到了如何应用一个插件,那么我们将更深入地了解它。插件可以从Gradle插件门户、Maven仓库或本地文件应用。

  • 从Gradle插件门户应用(目前主流做法,简洁):

    plugins {id 'org.springframework.boot' version '2.5.4'
    }
    
  • 从Maven仓库应用:

    buildscript {repositories {mavenCentral()}dependencies {classpath("org.springframework.boot:spring-boot-gradle-plugin:2.5.4")}
    }apply plugin: 'org.springframework.boot'
    
  • 从本地文件应用:

    apply from: 'other.gradle'
    

8.3 插件的配置

大多数插件都提供了一组可配置的属性来定制它们的行为。例如,application插件允许你指定应用的主类:

application {mainClassName = 'com.example.Main'
}

建议查看官方文档或插件的文档来了解所有可用的配置选项。


多项目构建

大型应用程序和库通常不仅仅是一个孤立的项目。它们可能由多个子项目组成,每个子项目都负责特定的功能。Gradle支持多项目构建,允许你在一个构建中管理和编译多个项目。

9.1 设置子项目

在你的主项目目录下,创建一个settings.gradle文件(如果尚未存在),并声明子项目:

include 'subproject1', 'subproject2'

此处的subproject1subproject2是子项目的目录名。

9.2 配置和执行跨项目的任务

每个子项目都可以有自己的build.gradle文件,其中定义了该子项目的构建逻辑。但在根项目中,你可以定义影响所有子项目的构建逻辑:

subprojects {apply plugin: 'java'repositories {mavenCentral()}dependencies {testImplementation 'junit:junit:4.12'}
}

上面的代码片段将Java插件、Maven Central仓库和JUnit依赖添加到所有子项目中。
要在所有子项目上执行任务,只需在根目录下运行该任务。例如,运行gradle build将构建所有子项目。
如果只想在一个特定的子项目上执行任务,可以这样:

gradle :subproject1:build

多项目构建是Gradle的强大特性之一,尤其是对于大型的代码库。通过合适地组织和配置,你可以确保整个代码库的一致性和可维护性。


自定义任务和扩展

10.1 编写自己的任务

在创建自定义任务时,推荐使用tasks.register方法来注册新的任务。这是一个懒加载的方法,意味着任务只有在真正需要时才会创建。

abstract class HelloTask extends DefaultTask {@TaskActiondef sayHello() {println 'Hello, Gradle!'}
}tasks.register('hello', HelloTask)

此处使用abstract关键字是因为Gradle会为任务生成具体的实现。
运行gradle hello将输出Hello, Gradle!
在这里插入图片描述

10.2 使用Gradle的API

对于现有的任务,我们通常使用tasks.withType来对某种特定类型的所有任务进行配置:

tasks.withType(HelloTask).configureEach {// 这里可以为每个HelloTask类型的任务进行配置
}

10.3 扩展的概念

Gradle扩展依然是为项目定义自定义属性的推荐方式。但在新的API中,推荐使用extensions.create的方式:

extensions.create('myExtension', MyExtension)abstract class MyExtension {String customProperty = 'default value'
}

通过自定义任务和扩展,你可以使Gradle构建过程更加灵活和强大。它们提供了一种机制,使你可以适应项目的特定需求,同时还能保持构建脚本的可读性和组织性。


构建缓存和增量构建

构建优化对于大型项目和频繁的构建操作非常关键。Gradle 提供了两个强大的特性来加速构建:构建缓存和增量构建。

11.1 为什么需要缓存?

每次运行构建时,都有很多任务是重复的,尤其是在没有对代码或资源做任何修改的情况下。构建缓存的作用是存储已经执行过的任务的输出,以便在将来的构建中重用,从而避免不必要的工作。

11.2 构建缓存的使用和配置

默认情况下,Gradle 使用本地构建缓存。你可以通过以下方式在项目的 settings.gradlesettings.gradle.kts 文件中启用或禁用它:

buildCache {local {enabled = true}
}

此外,Gradle 也支持远程构建缓存,这在团队开发中非常有用,因为它允许团队成员之间共享构建的输出。

11.3 增量构建

增量构建是指只对自上次构建以来发生变化的部分进行构建。为了使任务支持增量构建,你需要确保:

  • 使用@Input@Output注解来声明任务的输入和输出。
  • 使用@Incremental注解在TaskAction方法上。
    Gradle 会自动跟踪这些输入和输出之间的变化,并在可能的情况下只执行所需的工作。

11.4 示例:增量构建

假设我们有一个任务,该任务将源文件从一个目录复制到另一个目录,并将所有文件的扩展名更改为 .txt。我们可以这样做:

11.4.1添加一个自定义任务

build.gradle 文件的顶部,添加以下内容:

import org.gradle.work.InputChanges
abstract class IncrementalCopyTask extends DefaultTask {@InputDirectoryabstract DirectoryProperty getSourceDir()@OutputDirectoryabstract DirectoryProperty getTargetDir()@TaskActionvoid executeIncremental(InputChanges inputChanges) {inputChanges.getFileChanges(getSourceDir()).each { change ->switch (change.changeType.name()) {case "ADDED":case "MODIFIED":def targetFile = new File(getTargetDir().asFile, change.file.name + '.txt')change.file.copyTo(targetFile)breakcase "REMOVED":new File(getTargetDir().asFile, change.file.name + '.txt').delete()break}}}
}

build.gradle 的底部,注册这个任务:

tasks.register('incrementalCopy', IncrementalCopyTask) {sourceDir = file('src/main/resources')targetDir = file("$buildDir/output")
}

这样,我们就为 src/main/resources 目录中的文件定义了一个增量复制任务,输出目录是 build/output

11.4.2运行任务

为了测试这个任务,你可以首先在 src/main/resources 中创建一些文件,然后运行:

$ gradle incrementalCopy

你会看到这些文件被复制到 build/output 目录,并且它们的扩展名都被更改为 .txt

如果你再次运行该任务,不做任何改动,Gradle 会检测到没有任何变化,因此不会执行任何复制操作,这就是增量构建的威力。试试在 src/main/resources 中添加、修改或删除文件,然后再次运行任务。你会看到只有发生变化的文件才会被处理。这就是一个简单的增量构建示例。你可以在此基础上进一步扩展或修改来满足你的实际需求。


Gradle Wrapper的使用

12.1 什么是Gradle Wrapper?

Gradle Wrapper是一个工具,允许你在没有预先安装Gradle的情况下执行构建。这样做的好处是可以确保每个开发者和持续集成工具都使用相同版本的Gradle,避免了“在我的机器上可以运行”这样的问题。Wrapper由一个小的gradlew(Unix系统)或gradlew.bat(Windows系统)脚本和一些库文件组成。

12.2 为什么要使用Gradle Wrapper?

  1. 版本一致性:确保每个开发者和CI环境都使用相同的Gradle版本。
  2. 简化构建过程:开发者无需手动安装特定版本的Gradle。
  3. 灵活性:项目可以很容易地切换到新的Gradle版本,只需修改Wrapper配置即可。

12.3 如何设置Gradle Wrapper?

大部分通过gradle init初始化的新项目默认就包含了Wrapper。但如果你的项目还没有Wrapper,可以很容易地添加:

$ gradle wrapper --gradle-version=7.2

这会为你的项目生成Wrapper脚本和相关配置。

12.4 如何使用Gradle Wrapper?

一旦你的项目配置了Wrapper,你应该使用Wrapper脚本来运行所有Gradle任务,而不是直接使用gradle命令。例如:
在Unix或macOS上:

$ ./gradlew <task>

在Windows上:

> gradlew.bat <task>

如果你看到有人在项目的README或构建指南中推荐使用gradlew而不是gradle,这就是为什么。

12.5更新Gradle Wrapper的版本

随着Gradle的发展,你可能想要更新项目中的Gradle版本。使用Wrapper,这变得很容易。例如,要更新到Gradle 7.3,你可以运行:

$ ./gradlew wrapper --gradle-version=7.3

这会更新Wrapper使用的Gradle版本,并下载必要的文件。

总结

Gradle Wrapper是Gradle的一个强大特性,它确保了构建的一致性和简化了开发和CI环境的配置。为你的项目使用Wrapper是一个最佳实践,无论项目大小都推荐这样做。


参考文献

  1. 云原生—Gradle和Maven性能对比及技术选型 - 稀土掘金
  2. Gradle | Releases - 官方文档
  3. Gradle | Plugins - 官方文档
  4. Gradle 比 Maven 好为什么用的人少? - 知乎
  5. Gradle 快速入门
  6. Gradle 详细手册(从入门到入土) - 稀土掘金
  7. 如何使用Gradle管理多模块Java项目 - 知乎
  8. Android—Gradle教程(一) - 稀土掘金
  9. GradleUserGuide - GitHub
  10. Github Actions - GitHub

  1. https://juejin.cn/post/7209178782657675319 ↩︎

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/142827.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

ArduPilot开源飞控之GCS显示DPS310异常问题

ArduPilot开源飞控之GCS显示DPS310异常问题 1. 源由2. 现象3. 分析3.1 Mission Planner3.2 Ardupilot3.3 AP_Baro分析3.4 AP_Baro定位 4. 修复5. 效果6. 参考资料7. 补充7.1 Ardupilot提交PR注意事项7.2 修复主要使用到的命令 1. 源由 2020年Ardupilot官网论坛就有开始讨论DPS…

Learn Prompt- Midjourney案例:动漫设计

使用 Midjourney 生成动漫有两种方法&#xff1a;使用Niji模式或使用标准的 Midjourney 模型。Niji V5 是 Midjourney 的动漫专用模型。它建立在标准 Midjourney 模型的全新架构之上&#xff0c;更擅长生成命名的动漫角色。Niji V4于2023年12月发布&#xff0c;Niji V5于2023年…

国内大语言模型的相对比较:ChatGLM2-6B、BAICHUAN2-7B、通义千问-6B、ChatGPT3.5

一、 前言 国产大模型有很多&#xff0c;比如文心一言、通义千问、星火、MOSS 和 ChatGLM 等等&#xff0c;但现在明确可以部署在本地并且开放 api 的只有 MOOS 和 ChatGLM。MOOS 由于需要的 GPU 显存过大&#xff08;不量化的情况下需要80GB&#xff0c;多轮对话还是会爆显存…

网络安全--IDS--入侵检测

1. 什么是IDS&#xff1f; IDS---入侵检测是防火墙的一个有力补充&#xff0c;形成防御闭环&#xff0c;可以及时、准确、全面的发现入侵弥补防火墙对应用层检查的缺失。对系统的运行状态进行监视&#xff0c;发现各种攻击企图、过程、结果&#xff0c;来保证系统资源的安全&a…

【图论C++】链式前先星(图(树)的存储)

/*** file * author jUicE_g2R(qq:3406291309)————彬(bin-必应)* 一个某双流一大学通信与信息专业大二在读 * * brief 一直在竞赛算法学习的路上* * copyright 2023.9* COPYRIGHT 原创技术笔记&#xff1a;转载需获得博主本人…

Go 多版本管理工具

Go 多版本管理工具 文章目录 Go 多版本管理工具一、go get 命令1.1 使用方法&#xff1a; 二、Goenv三、GVM (Go Version Manager)四、voidint/g4.1 安装4.2 冲突4.3 使用 在平时开发中&#xff0c;本地新旧项目并行开发的过程中&#xff0c;你大概率会遇到一个令人头疼的问题&…

OmniOutliner 5 Pro for Mac(信息大纲记录工具)v5.12正式版 支持M1、M2

OmniOutliner 5 Pro是一款功能强大的大纲工具&#xff0c;可以帮助用户进行头脑风暴、组织思维和创建结构化的笔记。以下是这款软件的一些主要功能和特点&#xff1a; 大纲模式。OmniOutliner 5 Pro支持全屏模式、分屏模式、实时预览模式和导航模式等多种创作模式&#xff0c;…

【深度学习】【Opencv】Python/C++调用onnx模型【基础】

【深度学习】【Opencv】python/C调用onnx模型【基础】 提示:博主取舍了很多大佬的博文并亲测有效,分享笔记邀大家共同学习讨论 文章目录 【深度学习】【Opencv】python/C调用onnx模型【基础】前言Python版本OpenCVWindows平台安装OpenCVopencv调用onnx模型 C版本OpenCVWindows平…

Linux shell编程学习笔记3:查询系统中已安装可以使用的shell

〇、更新记录 20230926 编写 一、前言 目前可以在Linux系统上运行的shell有许多种&#xff1a;sh、bash、cshell、tcsh、zsh……但是对一台具体的系统来说&#xff0c;未必包括上面列的所有这些shell&#xff0c;很可能包括其中两三个。 那么我们如何查询系统中已经安装有哪…

性能测试之使用Jemeter对HTTP接口压测

我们不应该仅仅局限于某一种工具&#xff0c;性能测试能使用的工具非常多&#xff0c;选择适合的就是最好的。笔者已经使用Loadrunner进行多年的项目性能测试实战经验&#xff0c;也算略有小成&#xff0c;任何性能测试&#xff08;如压力测试、负载测试、疲劳强度测试等&#…

Git与Repo:开源开发的得力工具组合

Git与Repo&#xff1a;开源开发的得力工具组合 1. 引言 开源开发在当今的软件行业中扮演着至关重要的角色。它不仅推动了技术的创新和进步&#xff0c;也促进了开发者之间的合作与共享。随着越来越多的开源项目的涌现&#xff0c;有效的代码管理和版本控制成为了必不可少的工…

8. 基于消影点进行相机内参(主点)的标定

目录 1. ocam模型2. 消影点3. 基于消影点进行相机主点标定3.1 基于ocam模型的主点标定 感谢大家的阅读。 1. ocam模型 可以参考我的另一篇博客ocam模型。 这里简单提一下ocam模型&#xff1a; 这个模型将中心折反射相机和鱼眼相机统一在一个通用模型下&#xff0c;也称为泰勒模…

python基于轻量级卷积神经网络模型GhostNet开发构建养殖场景下生猪行为识别系统

养殖业的数字化和智能化是一个综合应用了互联网、物联网、人工智能、大数据、云计算、区块链等数字技术的过程&#xff0c;旨在提高养殖效率、提升产品质量以及促进产业升级。在这个过程中&#xff0c;养殖生猪的数字化智能化可以识别并管理猪的行为。通过数字化智能化系统&…

Linux0.11——操作系统怎么把自己从硬盘搬到内存

这里先直接给出答案&#xff1a;中断 此时&#xff0c;操作系统用短短几行代码&#xff0c;将数据段寄存器ds和代码段寄存器cs设置为了0x9000&#xff0c;方便之后的程序访问代码和数据&#xff0c;并且将栈顶地ss:sp设置在了远离代码的位置0x9000足够遥远的0x9FF00&#xff0c…

鸿鹄工程项目管理系统 Spring Cloud+Spring Boot+Mybatis+Vue+ElementUI+前后端分离构建工程项目管理系统

. 项目背景 一、随着公司的快速发展&#xff0c;企业人员和经营规模不断壮大。为了提高工程管理效率、减轻劳动强度、提高信息处理速度和准确性&#xff0c;公司对内部工程管理的提升提出了更高的要求。 二、企业通过数字化转型&#xff0c;不仅有利于优化业务流程、提升经营管…

LLM各层参数详细分析(以LLaMA为例)

网上大多分析LLM参数的文章都比较粗粒度&#xff0c;对于LLM的精确部署不太友好&#xff0c;在这里记录一下分析LLM参数的过程。 首先看QKV。先上transformer原文 也就是说&#xff0c;当h&#xff08;heads&#xff09; 1时&#xff0c;在默认情况下&#xff0c; W i Q W_i^…

电商项目高级篇-02 elasticsearch-下

电商项目高级篇-02 elasticsearch-下 4.2、QueryDSL返回指定字段 4.2、QueryDSL 返回指定字段 返回单个字段 GET bank/_search {"query": {"match_all": {}}, "sort": [{"balance": {"order": "desc"}}], &quo…

详解yolov1理论 代码

目标检测要解决的3大问题&#xff1a; 1、有没有&#xff1f; 图片中是否有要检测的物体&#xff1f;&#xff08;检测物体&#xff0c;判定前景背景&#xff09; 2、是什么&#xff1f; 这些物体分别是什么&#xff1f;&#xff08;检测到的物体是什么&#xff09; 3、在…

【RV1103】RTL8723bs (SD卡形状模块)驱动开发

文章目录 前言硬件分析Luckfox Pico的SD卡接口硬件原理图LicheePi zero WiFiBT模块总结 正文Kernel WiFi驱动支持Kernel 设备树支持修改一&#xff1a;修改二&#xff1a; SDK全局配置支持 wifi全局编译脚本支持编译逻辑拷贝rtl8723bs的固件到文件系统的固定目录里面去 上电后手…

Learn Prompt- Midjourney案例:Logo设计

Logo设计是一个充满挑战的任务&#xff0c;因为Logo是品牌重要价值的浓缩。 快速开始​ 直接使用logo design for...来获取灵感。 备注 图像中生成文字在Midjourney中的效果还不是很好&#xff0c;但你可以用Canva编辑图片并替换自己的文字。 在提示中使用那些擅长你所寻找的…