Maven知识点总结

news2025/1/11 21:48:58

Maven 基础课程第一天
第1章 Maven 介绍

1.1什么是 Maven

1.1.1什么是 Maven

Maven 的正确发音是[ˈmevən],而不是“马瘟”以及其他什么瘟。Maven 在美国是一个口语化的词语,代表专家、内行的意思。
一个对Maven 比较正式的定义是这么说的:Maven 是一个项目管理工具,它包含了一个项目对象模型 (POM:Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个依赖管理系统(Dependency Management System),和用来运行定义在生命周期阶段(phase)中插件(plugin)目标 (goal)的逻辑。

1.1.2Maven 能解决什么问题

可以用更通俗的方式来说明。我们知道,项目开发不仅仅是写写代码而已,期间会伴随着各种 必不可少的事情要做,下面列举几个感受一下:

1、我们需要引用各种 jar 包,尤其是比较大的工程,引用的 jar 包往往有几十个乃至上百个, 每用到一种jar 包,都需要手动引入工程目录,而且经常遇到各种让人抓狂的 jar 包冲突,版本冲突。

2、我们辛辛苦苦写好了 Java 文件,可是只懂 0 和 1 的白痴电脑却完全读不懂,需要将它编译成二进制字节码。好歹现在这项工作可以由各种集成开发工具帮我们完成,Eclipse、IDEA 等都可以将代码即时编译。当然,如果你嫌生命漫长,何不铺张,也可以用记事本来敲代码,然后用 javac 命令一个个地去编译,逗电脑玩。

3、世界上没有不存在 bug 的代码,计算机喜欢 bug 就和人们总是喜欢美女帅哥一样。为了追求美为了减少 bug,因此写完了代码,我们还要写一些单元测试,然后一个个的运行来检验代码质量。

4、再优雅的代码也是要出来卖的。我们后面还需要把代码与各种配置文件、资源整合到一起,定型 打包,如果是 web 项目,还需要将之发布到服务器,供人蹂躏。

试想,如果现在有一种工具,可以把你从上面的繁琐工作中解放出来,能帮你构建工程,管理 jar 包,编译代码,还能帮你自动运行单元测试,打包,生成报表,甚至能帮你部署项目,生成 Web 站点,你会心动吗?Maven 就可以解决上面所提到的这些问题。

1.1.3Maven 的优势举例

前面我们通过 Web 阶段项目,要能够将项目运行起来,就必须将该项目所依赖的一些 jar 包添加到工程中,否则项目就不能运行。试想如果具有相同架构的项目有十个,那么我们就需要将这一份 jar 包复制到十个不同的工程中。我们一起来看一个CRM 项目的工程大小。
使用传统Web 项目构建的CRM 项目如下:
在这里插入图片描述
原因主要是因为上面的WEB 程序要运行,我们必须将项目运行所需的 Jar 包复制到工程目录中,从而导致了工程很大。
同样的项目,如果我们使用Maven 工程来构建,会发现总体上工程的大小会少很多。如下图:

小结:可以初步推断它里面一定没有jar 包,继续思考,没有jar 包的项目怎么可能运行呢?

1.2Maven 的两个经典作用

1.2.1Maven 的依赖管理
在这里插入图片描述

Maven 的一个核心特性就是依赖管理。当我们涉及到多模块的项目(包含成百个模块或者子项目),管理依赖就变成一项困难的任务。Maven 展示出了它对处理这种情形的高度控制。
传统的WEB 项目中,我们必须将工程所依赖的 jar 包复制到工程中,导致了工程的变得很大。那么
maven 工程是如何使得工程变得很少呢? 分析如下:
通过分析发现:maven 工程中不直接将jar 包导入到工程中,而是通过在 pom.xml 文件中添加所需jar 包的坐标,这样就很好的避免了jar 直接引入进来,在需要用到jar 包的时候,只要查找pom.xml 文件,再通过 pom.xml 文件中的坐标,到一个专门用于”存放 jar 包的仓库”(maven 仓库)中根据坐标从而找到这些jar 包,再把这些jar 包拿去运行。
那么问题来了
第一:”存放jar 包的仓库”长什么样?
第二:通过读取 pom.xml 文件中的坐标,再到仓库中找到 jar 包,会不会很慢?从而导致这种方式不可行!

第一个问题:存放 jar 包的仓库长什么样,这一点我们后期会分析仓库的分类,也会带大家去看我们的本地的仓库长什么样。
第二个问题:通过pom.xml 文件配置要引入的jar 包的坐标,再读取坐标并到仓库中加载jar 包,这样我们就可以直接使用jar 包了,为了解决这个过程中速度慢的问题,maven 中也有索引的概念,通过建立索引,可以大大提高加载 jar 包的速度,使得我们认为 jar 包基本跟放在本地的工程文件中再读取出来的速度是一样的。这个过程就好比我们查阅字典时,为了能够加快查找到内容,书前面的 目录就好比是索引,有了这个目录我们就可以方便找到内容了,一样的在maven 仓库中有了索引我们就可以认为可以快速找到jar 包。

1.2.2项目的一键构建

我们的项目,往往都要经历编译、测试、运行、打包、安装 ,部署等一系列过程。
什么是构建?
指的是项目从编译、测试、运行、打包、安装 ,部署整个过程都交给 maven 进行管理,这个过程称为构建。
一键构建
指的是整个构建过程,使用 maven 一个命令可以轻松完成整个工作。

Maven 规范化构建流程如下:

我们一起来看 Hello-Maven 工程的一键运行的过程。通过 tomcat:run 的这个命令,我们发现现在的工程编译,测试,运行都变得非常简单。

第2章 Maven 的使用

2.1Maven 的安装

2.1.1Maven 软件的下载

为了使用Maven 管理工具,我们首先要到官网去下载它的安装软件。通过百度搜索“Maven“如下:
点击Download 链接,就可以直接进入到Maven 软件的下载页面:

目前最新版是apache-maven-3.5.3 版本,我们当时使用的是 apache-maven-3.5.2 版本,大家也可以下载最新版本。
Apache-maven-3.5.2 下载地址:http://archive.apache.org/dist/maven/maven-3/ 下载后的版本如下:

2.1.2Maven 软件的安装

Maven 下载后,将Maven 解压到一个没有中文没有空格的路径下,比如 D:\software\maven 下面。解压后目录结构如下:
bin:存放了maven 的命令,比如我们前面用到的mvn tomcat:run boot:存放了一些maven 本身的引导程序,如类加载器等
conf:存放了maven 的一些配置文件,如 setting.xml 文件
lib:存放了maven 本身运行所需的一些jar 包
至此我们的maven 软件就可以使用了,前提是你的电脑上之前已经安装并配置好了 JDK。

2.1.3JDK 的准备及统一

本次课程我们所使用工具软件的统一,JDK 使用JDK8 版本

  1. JDK 环境:

2.1.4Maven 及 JDK 配置

电脑上需安装java 环境,安装JDK1.7 + 版本 (将JAVA_HOME/bin 配置环境变量path ),我们使用的是JDK8 相关版本

配置 MAVEN_HOME ,变量值就是你的maven 安装 的路径(bin 目录之前一级目录)

上面配置了我们的Maven 软件,注意这个目录就是之前你解压 maven 的压缩文件包在的的目录,最好不要有中文和空格。
再次检查JDK 的安装目录,如下图:

2.1.5Maven 软件版本测试

通过 mvn -v 命令检查 maven 是否安装成功,看到 maven 的版本为 3.5.2 及java 版本为 1.8 即为安装成功。
找开cmd 命令,输入mvn –v 命令,如下图:

我们发现maven 的版本,及jdk 的版本符合要求,这样我们的maven 软件安装就成功了。

2.2Maven 仓库

2.2.1Maven 仓库的分类

maven 的工作需要从仓库下载一些 jar 包,如下图所示,本地的项目 A、项目 B 等都会通过 maven 软件从远程仓库(可以理解为互联网上的仓库)下载 jar 包并存在本地仓库,本地仓库 就是本地文件夹,当第二次需要此 jar 包时则不再从远程仓库下载,因为本地仓库已经存在了,可以将本地仓库理解为缓存,有了本地仓库就不用每次从远程仓库下载了。

下图描述了maven 中仓库的类型:

本地仓库 :用来存储从远程仓库或中央仓库下载的插件和jar 包,项目使用一些插件或jar 包, 优先从本地仓库查找
默认本地仓库位置在 u s e r . d i r / . m 2 / r e p o s i t o r y , {user.dir}/.m2/repository, user.dir/.m2/repository{user.dir}表示windows 用户目录。

远程仓库:如果本地需要插件或者jar 包,本地仓库没有,默认去远程仓库下载。远程仓库可以在互联网内也可以在局域网内。

中央仓库 :在 maven 软件中内置一个远程仓库地址 http://repo1.maven.org/maven2 ,它是中央仓库,服务于整个互联网,它是由 Maven 团队自己维护,里面存储了非常全的 jar 包,它包含了世界上大部分流行的开源项目构件。

2.2.2Maven 本地仓库的配置

本课程是在无网的状态下学习,需要配置老师提供的本地仓库,将 “repository.rar”解压至自己的电脑上,我们解压在 D:\repository 目录下(可以放在没有中文及空格的目录下)。

在MAVE_HOME/conf/settings.xml 文件中配置本地仓库位置(maven 的安装目录下):
打开 settings.xml 文件,配置如下:

2.2.3全局 setting 与用户 setting

maven 仓库地址、私服等配置信息需要在setting.xml 文件中配置,分为全局配置和用户配置。在 maven 安装目录下的有 conf/setting.xml 文件,此 setting.xml 文件用于 maven 的所有 project
项目,它作为maven 的全局配置。
如需要个性配置则需要在用户配置中设置,用户配置的 setting.xml 文件默认的位置在: u s e r . d i r / . m 2 / s e t t i n g s . x m l 目录中 , {user.dir} /.m2/settings.xml 目录中, user.dir/.m2/settings.xml目录中,{user.dir} 指windows 中的用户目录。
maven 会先找用户配置,如果找到则以用户配置文件为准,否则使用全局配置文件。

2.3Maven 工程的认识

2.3.1Maven 工程的目录结构

作为一个maven 工程,它的 src 目录和pom.xml 是必备的。进入 src 目录后,我们发现它里面的目录结构如下:

src/main/java —— 存放项目的.java 文件
src/main/resources —— 存放项目资源文件,如 spring, hibernate 配置文件src/test/java —— 存放所有单元测试.java 文件,如JUnit 测试类src/test/resources —— 测试资源文件
target —— 项目输出位置,编译后的class 文件会输出到此目录
pom.xml——maven 项目核心配置文件

注意:如果是普通的java 项目,那么就没有webapp 目录。

2.3.2Maven 工程的运行

进入maven 工程目录(当前目录有pom.xml 文件),运行 tomcat7:run 命令。

根据上边的提示信息,通过浏览器访问:http://localhost:8080/maven-helloworld/

2.3.3问题处理

如果本地仓库配置错误会报下边的错误

分析:
maven 工程运行先从本地仓库找jar 包,本地仓库没有再从中央仓库找,上边提示downloading…
表示 从中央仓库下载jar,由于本地没有联网,报错。

解决:
在maven 安装目录的conf/setting.xml 文件中配置本地仓库,参考“:maven 仓库/配置本地仓库章节”。

第3章 Maven 常用命令

我们可以在cmd 中通过一系列的maven 命令来对我们的maven-helloworld 工程进行编译、测试、运行、打包、安装、部署。

3.1.1compile

compile 是 maven 工程的编译命令,作用是将 src/main/java 下的文件编译为 class 文件输出到 target
目录下。

cmd 进入命令状态,执行mvn compile,如下图提示成功:

查看 target 目录,class 文件已生成,编译完成。

3.1.2test

test 是maven 工程的测试命令 mvn test,会执行src/test/java 下的单元测试类。
cmd 执行mvn test 执行 src/test/java 下单元测试类,下图为测试结果,运行 1 个测试用例,全部成功。

3.1.3clean

clean 是maven 工程的清理命令,执行 clean 会删除target 目录及内容。

3.1.4package

package 是maven 工程的打包命令,对于java 工程执行package 打成jar 包,对于web 工程打成war
包。

3.1.5install

install 是maven 工程的安装命令,执行install 将maven 打成jar 包或 war 包发布到本地仓库。从运行结果中,可以看出:
当后面的命令执行时,前面的操作过程也都会自动执行,

3.1.6Maven 指令的生命周期

maven 对项目构建过程分为三套相互独立的生命周期,请注意这里说的是“三套”,而且“相互独立”,这三套生命周期分别是:

Clean Lifecycle 在进行真正的构建之前进行一些清理工作。
Default Lifecycle 构建的核心部分,编译,测试,打包,部署等等。
Site Lifecycle 生成项目报告,站点,发布站点。

3.1.7maven 的概念模型

Maven 包含了一个项目对象模型 (Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个依赖管理系统(Dependency Management System),和用来运行定义在生命周期阶段(phase)中插件(plugin)目标(goal)的逻辑。

项目对象模型 (Project Object Model)
一个maven 工程都有一个pom.xml 文件,通过 pom.xml 文件定义项目的坐标、项目依赖、项目信息、插件目标等。

依赖管理系统(Dependency Management System)
通过maven 的依赖管理对项目所依赖的jar 包进行统一管理。
比如:项目依赖 junit4.9,通过在 pom.xml 中定义junit4.9 的依赖即使用junit4.9,如下所示是 junit4.9
的依赖定义:

一个项目生命周期(Project Lifecycle)
使用maven 完成项目的构建,项目构建包括:清理、编译、测试、部署等过程,maven 将这些过程规范为一个生命周期,如下所示是生命周期的各各阶段:

maven 通过执行一些简单命令即可实现上边生命周期的各各过程,比如执行 mvn compile 执行编译、执行mvn clean 执行清理。

一组标准集合
maven 将整个项目管理过程定义一组标准,比如:通过maven 构建工程有标准的目录结构,有标准的生命周期阶段、依赖管理有标准的坐标定义等。

插件(plugin)目标(goal)
maven 管理项目生命周期过程都是基于插件完成的。

3.2 idea 开发 maven 项目

在实战的环境中,我们都会使用流行的工具来开发项目。

3.2.1idea 的 maven 配置

3.2.1.1打开FileSettings 配置 maven

依据图片指示,选择本地 maven 安装目录,指定 maven 安装目录下conf 文件夹中 settings 配置文件。

3.2.2idea 中创建一个 maven 的 web 工程

打开idea,选择创建一个新工程

选择idea 提供好的maven 的web 工程模板

点击Next 填写项目信息

点击Next,此处不做改动。
点击Next 选择项目所在目录

点击Finish 后开始创建工程,耐心等待,直到出现如下界面。

手动添加 src/main/java 目录,如下图右键 main 文件夹NewDirectory
创建一个新的文件夹命名为java

点击OK 后,在新的文件夹java 上右键Make Directory asSources Root

3.2.2.1创建一个 Servlet

src/java/main 创建了一个Servlet,但报错

要解决问题,就是要将 servlet-api-xxx.jar 包放进来,作为maven 工程应当添加 servlet 的坐标,从而导入它的jar

3.2.2.2在 pom.xml 文件添加坐标

直接打开hello_maven 工程的pom.xml 文件,再添加坐标
添加jar 包的坐标时,还可以指定这个jar 包将来的作用范围。
每个 maven 工程都需要定义本工程的坐标,坐标是 maven 对 jar 包的身份定义,比如:入门程序的坐标定义如下:

com.pei

hello_maven

0.0.1-SNAPSHOT
:打包类型
jar:执行package 会打成jar 包
war:执行package 会打成war 包
pom :用于maven 工程的继承,通常父工程设置为pom

3.2.2.3坐标的来源方式

添加依赖需要指定依赖 jar 包的坐标,但是很多情况我们是不知道 jar 包的的坐标,可以通过如下方式查询:

3.2.2.3.1从互联网搜索

http://search.maven.org/ http://mvnrepository.com/
网站搜索示例:

3.2.3依赖范围

A 依赖 B,需要在 A 的 pom.xml 文件中添加 B 的坐标,添加坐标时需要指定依赖范围,依赖范围包括:

 compile:编译范围,指 A 在编译时依赖 B,此范围为默认依赖范围。编译范围的依赖会用在编译、测试、运行,由于运行时需要所以编译范围的依赖会被打包。

 provided:provided 依赖只有在当JDK 或者一个容器已提供该依赖之后才使用, provided 依赖在编译和测试时需要,在运行时不需要,比如:servlet api 被tomcat 容器提供。

 runtime:runtime 依赖在运行和测试系统的时候需要,但在编译的时候不需要。比如:jdbc 的驱动包。由于运行时需要所以runtime 范围的依赖会被打包。

 test:test 范围依赖 在编译和运行时都不需要,它们只有在测试编译和测试运行阶段可用, 比如:junit。由于运行时不需要所以test 范围依赖不会被打包。

system:system 范围依赖与 provided 类似,但是你必须显式的提供一个对于本地系统中JAR
文件的路径,需要指定 systemPath 磁盘路径,system 依赖不推荐使用。

在maven-web 工程中测试各各scop。测试总结:
默认引入 的jar 包 ------- compile 【默认范围 可以不写】(编译、测试、运行 都有效 )
servlet-api 、jsp-api ------- provided (编译、测试 有效, 运行时无效 防止和tomcat 下jar 冲突)
jdbc 驱动jar 包 ---- runtime (测试、运行 有效 )
junit ----- test (测试有效)
依赖范围由强到弱的顺序是:compile>provided>runtime>test

3.2.4项目中添加的坐标

3.2.5设置 jdk 编译版本

本教程使用jdk1.8,需要设置编译版本为 1.8,这里需要使用 maven 的插件来设置: 在pom.xml 中加入:

3.2.6编写 servlet

在 src/main/java 中创建ServletDemo

内容如下

3.2.7编写 jsp

3.2.8在 web.xml 中配置 servlet 访问路径

3.2.9添加 tomcat7 插件

在pom 文件中添加如下内容

此时点击idea 最右侧Maven Projects, 就可以看到我们新添加的tomcat7 插件
双击tomcat7 插件下tomcat7:run 命令直接运行项目

也可以直接点击如图按钮,手动输入tomc7:run 命令运行项目
点击后弹出如下图窗口

3.2.10运行结果

第4章 maven 工程运行调试

4.1端口占用处理

重新执行tomcat:run 命令重启工程,重启之前需手动停止 tomcat,否则报下边的错误:

4.2断点调试

点击如图所示选项
在弹出框中点击如图加号按钮找到maven 选项

在弹出窗口中填写如下信息

完成后先Apply 再OK 结束配置后,可以在主界面找到我们刚才配置的操作名称。
如上图红框选中的两个按钮,左侧是正常启动,右侧是 debug 启动。

第5章 总结

5.1maven 仓库

1、maven 仓库的类型有哪些?
2、maven 工程查找仓库的流程是什么?
3、本地仓库如何配置?

5.2常用的 maven 命令

常用 的maven 命令包括:
compile:编译clean:清理test:测试package:打包install:安装

5.3坐标定义

在pom.xml 中定义坐标,内容包括:groupId、artifactId、version,详细内容如下:

com.pei.maven

maven-first

0.0.1-SNAPSHOT
:打包类型
jar:执行package 会打成jar 包
war:执行package 会打成war 包
pom :用于maven 工程的继承,通常父工程设置为pom

5.4pom 基本配置

pom.xml 是Maven 项目的核心配置文件,位于每个工程的根目录,基本配置如下:

:文件的根节点 .
: pom.xml 使用的对象模型版本
:项目名称,一般写项目的域名
:模块名称,子项目名或模块名称
:产品的版本号 .
:打包类型,一般有jar、war、pom 等
:项目的显示名,常用于 Maven 生成的文档。
:项目描述,常用于 Maven 生成的文档
:项目依赖构件配置,配置项目依赖构件的坐标
:项目构建配置,配置编译、运行插件等。

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

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

相关文章

notepad++ 配置 python 以及Anaconda中的python(已解决)

说明,无论是自己的电脑单独安装的python 还是Anaconda虚拟环境安装的python都是一样的。区别就是 独立安装的python 的exe文件路径添加的环境变量了,不需要制定它的路径直接运行下面的命令就可以,而Anaconda中的python.exe的文件夹并没有在虚…

endnotes插入文献突然变得格式不对,而且也不是按照正常的顺序来插入解决办法

今天插入文献突然变成了endnotes里面的文献序号,而且也不导入了,多了作者和序号信息 解决办法: 更新一下,然后在进行的导入就ok了,能够按照以前的格式插入了,序号也能自动排开,而且也能导入文献…

从CNN(卷积神经网络),又名CAM获取热图

一、说明 卷积神经网络(CNN)令人难以置信。如果你想知道它如何看待世界(图像),有一种方法是可视化它。 这个想法是,我们从最后的密集层中得到权重,然后乘以最终的CNN层。这需要全局平均…

想要精通算法和SQL的成长之路 - 戳气球

想要精通算法和SQL的成长之路 - 戳气球 前言一. 戳气球1.1 记忆化搜索 前言 想要精通算法和SQL的成长之路 - 系列导航 一. 戳气球 原题链接 首先我们看一下题干:对于超出了数组边界的,就当做它是一个数字为1的气球。遇到这种的,我们可以考…

论文解读-DeepEdit:使用纳米孔直接RNA测序对A - to - I RNA编辑事件进行单分子检测和阶段划分

DOI: 10.1186/s13059-023-02921-0 期刊 :Genome Biology 中科院分区:1Q 影像因子:12.3 作者 Longxian Chen; Liang Ou; Xinyun Jing; Yawei Kong; Bingran Xie; et al 出版日期 2023-04-17 网址: https://genome…

Jetpack系列 -- LiveData源码原理解析(解决黏性问题)

一、LiveData是什么? 注意:一般情况下,LiveData要配合ViewModel一起使用的,但是今天是单独使用LiveData,作为学习的话,我们可以只关注LiveData了。 LiveData是一种可观察的数据存储器类。与常规的可观察类…

python-保留小数位数的3种方法

在python实际运用中,需要对小数位数进行截取保留。 以下是,python保留小数点位数的3种方法。 方法一 方法:’%.nf’ % num n代表保留的小数位数,num表示需要截取的目标数 用法如下: old_num 1.23456 new_num %.2f…

[NLP] LLM---<训练中文LLama2(四)方式一>对LLama2进行SFT微调

指令精调 指令精调阶段的任务形式基本与Stanford Alpaca相同。训练方案也采用了LoRA进行高效精调,并进一步增加了可训练参数数量。在prompt设计上,精调以及预测时采用的都是原版Stanford Alpaca不带input的模版。对于包含input字段的数据,采…

竞赛 基于机器学习与大数据的糖尿病预测

文章目录 1 前言1 课题背景2 数据导入处理3 数据可视化分析4 特征选择4.1 通过相关性进行筛选4.2 多重共线性4.3 RFE(递归特征消除法)4.4 正则化 5 机器学习模型建立与评价5.1 评价方式的选择5.2 模型的建立与评价5.3 模型参数调优5.4 将调参过后的模型重…

yolov5在rk3588上加速

不采用fastdeploy等三方框架,使用rknn-lite2或者rknpu在rk3588上加速,测试加速的是rknn自带的yolov5模型。 备注: 1.测试视频:多人,帧:3000,时长:2min,分辨率:1920x1080,fps:25 2…

傅里叶变换应用 (02/2):频域和相位

一、说明 到目前为止,在我们的讨论中,我已经交替使用了“傅里叶变换”和“快速傅里叶变换(FFT)”。在这一点上,值得注意的是区别!FFT 是“离散”傅里叶变换 (DFT) 的有效算法实现。“…

Remix+Cloudflare Pages+D1 快速上手

我们最近听到越来越多的关于Cloudflare的服务。 我对Clouflare D1特别感兴趣,所以我决定研究一下。 与这次我想使用的 Remix 一起,我想介绍 Remix Cloudflare Pages D1 的第一步。 我只是稍微地了解一下,但我所做的在下面的仓库中&#…

【深度学习】 Python 和 NumPy 系列教程(十二):NumPy详解:4、数组广播;5、排序操作

目录 一、前言 二、实验环境 三、NumPy 0、多维数组对象(ndarray) 多维数组的属性 1、创建数组 2、数组操作 3、数组数学 4、数组广播 5、排序操作 1. np.sort() 函数 2. np.argsort() 函数 3. ndarray.sort() 方法 4. 按列或行排序 5. n…

VHDL菜鸟入门到精通之激励文件编写

目录 一、概览 二、激励文件结构 三、样例 3.1 组合逻辑 3.2 时序逻辑 四、常用编写 4.1 时钟信号 4.2 延时 4.3 循环 4.4 进程 一、概览 二、激励文件结构 VHDL激励文件结构和设计文件较为类似,下面以3-8译码器的激励文件对结构进行说明。 激励文件主要…

git clone报错Failed to connect to github.com port 443 after 21055 ms:

git 设置代理端口号 git config --global http.proxy http://127.0.0.1:10085 和 git config --global https.proxy http://127.0.0.1:10085 然后就可以成功git clone hugging face的数据集了 如果是https://huggingface.co/datasets/shibing624/medical/tree/main 那么…

logstash通过kafka通道采集日志信息

1.修改文件/opt/app/elk/logstash-7.5.1/config.d/config1.conf,在input下添加kafka采集配置 #192.168.128.130:9103:kafka地址 #topics:主题 kafka {bootstrap_servers > ["192.168.128.130:9103"]group_id > "logstash"topics > [&…

Optuna学习博客

介绍 简单来说,OPtuna就是一个能够进行调整超参数的框架,它能够将自动调整超参数以及能够将超参数优化过程可视化,方便保存,分析。可拓展性较强。 使用方法 optuna的优化程序具体有三个组成部分。 objective(目标函…

MySQL数据库管理及数据库基本操作

目录 1 MySQL数据库基本操作 1.1 SQL分类 1.2 SQL语言规范 1.3 数据库对象和命名 1.4 SQL语句分类 2 管理MySQL数据库 2.1 查看数据库结构 2.1.1 查看当前服务器中的数据库 2.1.2 查看数据库中包含的表 2.1.3 查看表的结构(字段) 2.2 数据类型…

【linux】进程创建,进程终止

进程创建,进程终止 1.进程创建1.1写时拷贝1.2fork常规用法1.3fork调用失败的原因 2.进程终止2.1退出码2.2进程退出场景2.3进程如何退出 1.进程创建 在前面创建子进程的时候就学过了fork函数,它能从已经存在进程中创建一个新进程,新进程为子进…

Python 图形化界面基础篇:打开和关闭新窗口

Python 图形化界面基础篇:打开和关闭新窗口 引言 Tkinter 库简介步骤1:导入 Tkinter 模块步骤2:创建 Tkinter 窗口步骤3:创建一个新窗口步骤4:关闭新窗口步骤5:启动 Tkinter 主事件循环 完整示例代码代码解…