Maven面试题

news2024/10/5 20:33:38

以下是一些关于Maven的经典面试题以及它们的答案: 

1、什么是Maven?

Maven是一个项目管理工具,用于构建、管理、发布Java项目。

2、为什么要使用Maven而不是手动管理项目依赖?

Maven提供了依赖管理、统一的构建、打包、文档生成等功能,能帮助开发者减少手动管理项目的繁琐和错误,提高了项目的可维护性和可靠性

3、Maven的生命周期是什么?以及各个阶段的含义是什么?

Maven的生命周期是指Clean、Build、Site三个阶段,每个阶段又有多个子阶段。Clean阶段负责清理项目;Build阶段负责编译、测试、打包、安装和部署项目;Site阶段负责生成项目的站点文档。Maven的构建生命周期按照Clean、Build、Site的顺序执行,每个阶段都有特定的Maven插件去执行具体的构建任务,Maven提供了许多默认的插件,同时也允许开发者自定义和扩展插件,以满足项目的特定需求。

  • Clean阶段。这个周期主要用于清理项目,删除上一次构建生成的target文件。它的主要阶段包括pre-clean、clean和post-clean。pre-clean执行一些需要在clean之前完成的工作,clean移除所有上一次构建生成的文件,post-clean执行一些需要在clean之后立刻完成的工作。
  • Default阶段。这个周期是构建和发布项目的核心部分,包括编译、测试、打包、安装和部署等步骤。它的主要阶段包括validate、compile、test、package、verify、install和deployvalidate验证项目结构和配置文件是否是完整的正确的可用的,compile将源代码编译为可执行的字节码,test使用单元测试框架测试编译后的源代码,package获取已编译的代码,并将其打包为可发布的格式,如JAR,verify验证包是否满足Maven的构建规范,install将包安装到本地仓库,以供其他项目使用,deploy将包部署到远程仓库。
  • Site阶段。这个周期主要用于生成和发布项目的站点文档。它的主要阶段包括pre-site、site、post-site和site-deploy。pre-site完成站点文档生成前的准备工作,比如创建目录结构、复制静态内容等,site生成项目的站点文档(在这个阶段,Maven会根据项目配置的站点文档生成插件,生成HTML、XML、PDF等格式的文档),生成的文档可以包含项目信息:如描述、开发者、许可证等,Javadocs:描述项目中的类、接口和方法,报告:如单元测试报告、代码覆盖率报告(代码覆盖率表示测试用例执行时覆盖的代码量与总代码量的比例)、代码质量报告等,依赖列表:列出项目使用的依赖,模块关系:如果项目是多模块的,这部分将展示各模块之间的关系,post-site用于完成生成站点文档后的附加工作,site-deploy将生成的站点文档部署到特定的服务器上。

4、Maven的依赖管理是什么?如何在POM文件中定义依赖?

Maven的依赖管理是指通过POM文件来管理项目的外部依赖库。可以在POM文件的dependencies标签下,使用groupId、artifactId和version来定义依赖。

  • groupId:这是项目组的标识。它在一个组织或者项目中通常是唯一的。
  • artifactId:这是项目的标识,通常是工程的名称。它在一个项目组(group)下是唯一的。
  • version:这是项目的版本号,用来区分同一个artifact的不同版本。

5、Maven的仓库是什么?有哪些仓库类型?

Maven的仓库是存储项目依赖库的地方。类型包括本地仓库、远程仓库、中央仓库、私有仓库、快照仓库(Snapshot版本)和发行仓库(Release 版本)等。

6、如何发布项目到私有仓库?

可以在Maven的settings.xml文件中配置私有仓库的URL和认证信息,然后使用mvn deploy命令来发布项目到私有仓库。

7、如何跳过单元测试的执行?

可以使用-DskipTests=true参数来跳过单元测试的执行,如mvn clean install -DskipTests=true

8、如何指定Maven使用的JDK版本?

第一种(最省事):在maven的conf目录下修改settings.xml文件,在profiles中加入以下配置,设置maven.compiler.sourcemaven.compiler.target来指定使用的JDK版本。

<profile>    
	<id>jdk-1.8</id>    
	<activation>    
		<activeByDefault>true</activeByDefault>    
		<jdk>1.8</jdk>    
	</activation>    
	<properties>    
		<maven.compiler.source>1.8</maven.compiler.source>    
		<maven.compiler.target>1.8</maven.compiler.target>    
		<maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>    
	</properties>    
</profile>

第二种:在pom.xml中添加配置。

<properties>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>

    <maven.compiler.encoding>UTF-8</maven.compiler.encoding>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
</properties>

第三种:在pom.xml中添加配置,通过maven的插件实现。

<build>
  <plugins>
	<!-- 设置编译版本 -->
	<plugin>
	  <groupId>org.apache.maven.plugins</groupId>
	  <artifactId>maven-compiler-plugin</artifactId>
	  <configuration>
	    <source>1.8</source>
	    <target>1.8</target>
	    <encoding>UTF-8</encoding>
	  </configuration>
  </plugin>
</plugins>

9、描述一下Maven中的传递性依赖?如何排除传递性依赖?

Maven中的传递性依赖是指通过直接依赖间接依赖了其它的依赖库Maven会自动解析和加载这些传递性依赖。可以在POM文件的依赖声明中使用exclusions标签来排除传递性依赖。

10、如何创建一个Maven项目?

可以通过idea提供的菜单面板创建maven项目,也可以通过命令mvn archetype:generate创建。 

mvn archetype:generate
-DarchetypeGroupId=groupId
-DarchetypeArtifactId=artifactId
-DarchetypeVersion=version
-DgroupId=groupId
-DartifactId=artifactId
-Dversion=version

11、如何更新Maven依赖的版本?

可以使用mvn versions:update-parentmvn versions:use-latest-versions命令将项目中的依赖项更新到最新版本。如要显示项目中的依赖项是否有可用的更新版本,有命令mvn versions:display-dependency-updates 。

12、Maven中的optional和scope以及type作用?

optional

为true表示将依赖项设为可选,这样依赖该项目的项目,就不会引入该依赖,减少了依赖传递,避免依赖冲突,减小了jar和war体积,默认值为 false。 在某些情况下,项目可能依赖于两个或多个包含相互冲突的依赖项的库,通过将这些冲突的依赖项设置为可选,我们可以让项目显式地选择使用哪个版本,从而消除冲突。 

常见的有 spring-boot-devtools 热部署,junit 单元测试,lombok等生产环境下不需要的依赖包。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-devtools</artifactId>
    <optional>true</optional>
</dependency>
<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.12</version>
    <optional>true</optional>
</dependency>
<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
</dependency>

scope

scope 元素主要用来控制依赖的使用范围。

<scope>import</scope>的import只能在dependencyManagement中使用,且type必须为pom:

type

type:指明引入的依赖的类型(jar、war、pom等),默认jar。用到<scope>import</scope>时必须要声明<type>pom</type>。而<scope>import</scope>的import只能在dependencyManagement中用,所以<type>pom</type>常用在dependencyManagement标签中。

dependencyManagement标签用法会在本文章标题13中讲到。

13、Maven多模块项目中的继承和聚合有什么作用?

模块的“继承”

子 pom 通过继承父 pom 来复用父 pom的配置和依赖。

可继承的标签

可继承的标签太多了,不一一例举,这里就列一些我们在开发中常用的可继承的标签:

groupId、version:“项目所属组织”和“版本”可以继承(artifactId “模块名”不能继承)。
dependencies:“依赖”可以继承。
denpendencyManagement:“依赖管理”配置可以继承。

我们往往会把子模块中使用到的依赖以及版本号等,抽取到父模块中由子模块直接继承。

一般是用在最顶层的父pom,子模块继承之后锁定版本,能让所有的子模块中引用一个依赖而不用显式的列出版本号,Maven会沿着父子层向上走,直到找到一个拥有dependencyManagement元素的模块,然后他就会使用这个dependencyManagement元素中指定的版本号。这么做的好处就是,如果有多个子模块都引用同样的依赖,则可以避免在每个使用的子模块中的声明一个版本号。只需要在顶层父模块里更新,而不需要对子模块逐一进行修改,另外如果某个子项目中需要单独使用另外的版本,只需要在子模块中单独声明version即可dependencyManagement里面只是声明和限定依赖版本的,并未实现依赖的引入,因此子项目仍需要显式地声明所要引入的依赖如果不在子项目中声明依赖,是不会从父项目中继承下来的只有在子项目中引入了此依赖并且没有指定具体的版本号,才会从父项目中继承该项,并且version和scope都读取自父pom。如果子项目中定义了版本号,则会使用子项目中定义的版本号。

properties:“自定义属性”(类似于定义一个变量)可以继承。

repositories:仓库配置。

pom.xml文件中的 repositories 元素用于定义Maven构建系统在构建当前项目时从哪里获取依赖项。

<repositories>
    <repository>
        <id>central</id>
        <url>https://repo.maven.apache.org/maven2</url>
    </repository>
    <!-- 其他存储库的定义 -->
</repositories>

在这个例子中,repositories 包含了一个名为 “central” 的远程存储库,
该存储库的URL是Maven中央存储库的地址。
项目构建时,Maven将会在这个存储库中查找项目所需的依赖项。

将项目依赖的仓库信息直接定义在 pom.xml 中有一些优势:项目的构建不依赖于全局配置,可在不同环境中顺利构建,降低了对外部环境的依赖,使得项目更具可移植性

在实际的依赖项解析过程中,Maven按照以下顺序查找依赖项:本地仓库-->pom.xml 中的 repositories 标签配置的远程仓库--> Maven 配置文件 settings.xml 中的远程仓库配置-->
Maven内置默认仓库,例如 Maven Central Repository
。在这个过程中,一旦找到符合条件的依赖项,Maven就会停止搜索,避免不必要的网络请求。

distributionManagement:项目deploy的私服仓库配置。

build:插件、插件管理、源码输出位置等配置。

列举几个配置案例。

默认情况下,如果没有指定resources,自动会将classpath下的src/main/java下的.class文件和src/main/resources下的.xml文件放到target的classes文件夹下的package下的文件夹里。但如果设定了resources,那么默认的就会失效,就会以设置的为准。

pom.xml中的build标签的resources标签_pom build resources-CSDN博客

<resource>
    <directory>src/main/resources</directory>
</resource>

resource表示读取该目录的所有文件。

<resource>
  <directory>src/main/resources</directory>
  <filtering>true</filtering>
</resource>

filtering是否开启标签替换,无此标签表示不开启替换。若读取的文件中有类似${key}这样的配置,<filtering>true</filtering>就会从pom.xml中profiles的配置里面取。

<resource>
  <directory>src/main/resources</directory>
  <targetPath>META-INF/plexus</targetPath>
</resource>

targetPath用于指定读取资源到target的那个目录下,如下图,不指定默认为target/classes

<resource>
  <directory>src/main/resources</directory>
  <includes>
    <include>config/dubboSource/*.xml</include>
  </includes>
</resource>

includes表示仅读取directory文件夹下includes中指定的文件或文件夹的内容,即in的意思,如下图展示

<resource>
  <directory>src/main/resources</directory>
  <excludes>
    <exclude>config/dubboSource/*.xml</exclude>
  </excludes>
</resource>

excludes表示读取directory文件夹下但排除excludes中指定的文件或文件夹的所有其他内容,即not in的意思。

<testResources>
  <testResource>
    <directory>src/test/resources</directory>
    <filtering>true</filtering>
  </testResource>
</testResources>

testResources这个模块用来配置测试资源元素,其内容定义与resources类似。

子POM中引入父POM

父pom:

子pom引入父pom:

relativePath 指的是父 pom.xml 所在的相对路径,默认值是 ../pom.xml,如下图:
在这里插入图片描述

这也是 Maven 建议的目录组织形式,如果想将 parent模块 与 child 模块放到同一级目录,则需要修改为:<relativePath>../parent模块名/pom.xml</relativePath>,如下图:

模块的聚合

聚合(aggregation)用于按顺序批量构建子模块。

聚合的注意事项

在这个项目中,demo-a 依赖 demo-b, demo-b 依赖 demo-c , 在这种情况下,我们需要先 install c ,再 install b ,最后再构建 a,执行起来非常麻烦,为了处理这个问题,Maven 引入了聚合机制,可以将这三个模块聚合在一起,一次性完成构建。
聚合的语法也非常简单,只需要在父模块的 pom.xml 中添加 <modules> 即可:

<modules>
    <module>demo-a</module>
    <module>demo-b</module>
    <module>demo-c</module>
</modules>
<!-- 这里需要注意的是,<module> 中填写的并不是 artifactId,
而是需要被聚合的模块的 文件目录 的相对路径! -->

反应堆(reactor)

在一个多模块的Maven项目中,反应堆(Reactor)是指所有模块组成的一个构建结构,对于单模块的项目,反应堆就是该模块本身。我们使用上面聚合的项目来做一次构建:

mvn clean install

注意上面的执行顺序,先构建的是配置了聚合关系的父模块,然后才是子模块,子模块构建的时候会检查有没有依赖的模块,如果有就先构建被依赖的模块。所以这里按照被依赖的顺序,由底层向上层进行构建。因此,我们的模块之间不能出现循环依赖的情况,假如在demo-c中又引入demo-a的依赖,此时构建就会报错。

The projects in the reactor contain a cyclic reference: ......

在实际开发中,有时项目比较庞大,如果每次都完整的进行构建,耗时会很长。此时我们可以在构建指令上加上一些参数,以便于我们选择性的构建我们需要的项目,通过mvn -h查看。 

usage: mvn [options] [<goal(s)>] [<phase(s)>]

Options:
 -am,--also-make                        If project list is specified, also
                                        build projects required by the
                                        list
 -amd,--also-make-dependents            If project list is specified, also
                                        build projects that depend on
                                        projects on the list
 -B,--batch-mode                        Run in non-interactive (batch)
                                        mode (disables output color)
 -b,--builder <arg>                     The id of the build strategy to
                                        use
 -C,--strict-checksums                  Fail the build if checksums don't
                                        match
 -c,--lax-checksums                     Warn if checksums don't match
 -cpu,--check-plugin-updates            Ineffective, only kept for
                                        backward compatibility
 -pl,--projects <arg>          			Comma-delimited list of specified
										reactor projects to build instead
										of all projects. A project can be
										specified by [groupId]:artifactId
										or by its relative path

上面的-pl-am是比较常用的参数:

  • pl:指定构建某一个项目
  • am:构建项目的同时,构建它依赖的项目

假如我想指定构建demo-b及其依赖的模块demo-c,则可以用下面的指令:

mvn clean install -pl demo-b -am

14、Maven的插件是什么?如何配置插件?

插件是用于扩展Maven功能的工具,可以在项目的pom.xml文件中的build标签的子标签plugins中配置插件的参数来使用插件。

15、什么是Snapshot、Release版本?

Snapshot版本是指开发中的不稳定版本,用于表示项目的最新开发状态。一般来说Snapshot版本代表正在开发中的版本,而Release版本代表比较稳定的发布版本。

16、如何在Maven中配置插件?

在POM文件的build节点下使用插件块来配置插件。可以指定插件的groupId、artifactId、version,以及插件执行的目标等。

Maven中的profile是什么?如何使用profile?
Profile是一种Maven的特性,用于根据不同的环境配置来激活不同的构建选项。可以在POM文件中使用profile标签定义profile,并使用activation标签来指定profile的激活条件。

如何在Maven中跳过特定的构建阶段?
可以使用命令行参数或配置来跳过特定的构建阶段。例如,使用-Dmaven.test.skip=true参数可以跳过测试阶段。

Maven的聚合和继承有什么区别?什么时候使用聚合,什么时候使用继承?
聚合(aggregation)是将多个相互独立的模块组合成一个大项目。继承(inheritance)是使用父POM中的配置和依赖。聚合用于管理多模块项目,继承用于重用配置和依赖。

Maven中的插件管理是什么?如何在POM文件中配置插件管理?
插件管理是用于集中管理项目中使用的插件的配置。可以在POM文件的build节点下使用pluginManagement标签来配置插件管理,然后在plugins标签下配置具体的插件。

Maven中的依赖范围有哪些?
Maven的依赖范围包括:compile、provided、runtime、test和system。

Maven中的依赖冲突是什么?如何解决依赖冲突?
依赖冲突是指项目中多个依赖库引用了同一个依赖的不同版本,可能导致运行时的冲突。可以使用Maven的dependencyManagement机制来解决依赖冲突。

如何创建Maven插件?
可以使用Maven的插件骨架生成器(Maven Plugin Archetype Generator)来创建Maven插件的初始模板,并在模板基础上进行开发。 

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

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

相关文章

实现前端开发几个常用技巧

如何知道iframe下载完成 定时器轮询监听readyState的状态&#xff0c;如果是 complete 或者 interactive 说明文件加载完成。 常用的全屏居中 JS 函数 JS实现deepCopy 生成星级评分 JS数组扁平化之简单方法实现 toString 优点&#xff1a;简单&#xff0c;方便&#xff0c;对…

学习大语言模型(LLM),从这里开始

在见识了ChatGPT的各种强大能力后&#xff0c;不少 NLP一线从业人员很自然地想到&#xff0c;以后开发者只要借助 ChatGPT&#xff0c;就可以做到现在大部分NLP工程师在做的事&#xff0c;比如文本分类、实体抽取、文本推理等。甚至随着大语言模型&#xff08;largelanguagemod…

基于java+springboot女士电商平台系统源码+文档设计

基于javaspringboot女士电商平台系统源码文档设计 博主介绍&#xff1a;多年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《1000套》 欢迎点赞 收藏 ⭐留言 文末获取源…

WebStorm 2023:让您更接近理想的开发环境 mac/win版

JetBrains WebStorm 2023激活版下载是一款强大而智能的Web开发工具&#xff0c;专为提高开发人员的生产力而设计。这款编辑器提供了许多先进的代码编辑功能&#xff0c;以及一系列实用的工具和插件&#xff0c;可帮助您更快地编写、调试和测试代码。 WebStorm 2023软件获取 We…

【外汇天眼】交易技术三要素:趋势与震荡,突破与假突破,动力与约束

趋势与振盪 大多数人的做法是&#xff0c;假定当前所操作的品种是有趋势的&#xff0c;然后设法追随趋势。 其实最好先假定所操作的任何品种都是振盪的&#xff08;振盪中当然就是高沽低进&#xff09;&#xff0c;然后考察其是否存在趋势&#xff0c;或者有没有发展成趋势的倾…

泛域名ov https证书1590元买一年送一月

泛域名https证书一直是域名https证书中比较受欢迎的一款数字证书产品。泛域名https证书可以同时保护主域名以及主域名下所有的子域名&#xff0c;为多个网站提供信息加密和身份认证服务。在证书有效期内&#xff0c;即使组织或者企事业单位增加多个子域名站点&#xff0c;也不需…

.Net利用Microsoft.Extensions.DependencyInjection配置依赖注入

一、概述 为了让接口程序更加模块化和可测试,采用依赖注入的方式调用接口方法。 二、安装Microsoft.Extensions.DependencyInjection 在NuGet里面搜索Microsoft.Extensions.DependencyInjection,并进行安装。 三、代码编写 3.1 创建Service 实现类 /*****************…

Vue自定义商品发布组件

文章目录 一、代码展示二、代码解读三、结果展示 一、代码展示 <template><div><a-popover trigger"hover" :getPopupContainer"triggerNode > {return triggerNode.parentNode || document.body;}"><template #content><d…

matlab:涉及复杂函数图像的交点求解

matlab&#xff1a;涉及复杂函数图像的交点求解 在MATLAB中求解两个图像的交点是一个常见的需求。本文将通过一个示例&#xff0c;展示如何求解两个图像的交点&#xff0c;并提供相应的MATLAB代码。 画出图像 首先&#xff0c;我们需要绘制两个图像&#xff0c;以便直观地看…

自动驾驶技术详解

&#x1f3ac;个人简介&#xff1a;一个全栈工程师的升级之路&#xff01; &#x1f4cb;个人专栏&#xff1a;自动驾驶技术 &#x1f380;CSDN主页 发狂的小花 &#x1f304;人生秘诀&#xff1a;学习的本质就是极致重复! 目录 一 自动驾驶视觉感知算法 1目标检测 1.1 两阶…

vue-electron 项目创建记录及注意事项

vue-electron 项目创建记录及注意事项 1、使用vue ui或者命令行创建vue项目 2、添加electron插件 3、安装element-plus: npm install --save element-plus 4、修改配置文件如下图: vue.config.js增加配置&#xff1a; pluginOptions:{ electronOutput: { contextIsolation…

JVM(4)

垃圾回收问题 垃圾回收算法 通过之前的学习我们可以将死亡对象标记出来了,标记出来后我们就可以进行垃圾回收操作了,在正式学习垃圾处理器之前,我们先来看一下垃圾回收器使用的几种算法. 标记-清除算法 "标记-清除"算法是基础的收集算法.算法分为"标记"…

nextjs13如何进行服务端渲染?

目录 一、创建一个新项目 二、动态获取后端数据进行服务端渲染出现的问题 三、nextjs13如何进行服务端渲染 nextjs13是nextjs的一个重大升级&#xff0c;一些原本在next12当中使用的API在nextjs13上使用十分不便。本文将着重介绍在nextjs13及以上版本当中进行服务端渲染的方…

Java进阶(锁)——锁分类总结,Java中常用的锁的介绍

目录 引出锁分类总结1、乐观锁2、悲观锁3、自旋锁4、可重入锁5、读写锁6、公平锁7、非公平锁8、共享锁9、独占锁10、重量级锁11、轻量级锁12、偏向锁13、分段锁14、互斥锁15、同步锁16、死锁17、锁粗化18、锁消除 Java中常用的锁synchronizedLock和synchronized的区别Reentrant…

web组态(BY组态)接入流程

技术文档 官网网站&#xff1a;www.hcy-soft.com 体验地址&#xff1a; www.byzt.net:60/sm 一、数据流向图及嵌入原理 数据流向 嵌入原理 二、编辑器调用业务流程图 三、集成前需要了解的 1、后台Websocket端往前台监控画面端传输数据规则 后台websocket向客户端监控画面…

视频记录仪_基于联发科MT6762的智能4G记录仪方案

智能记录仪采用联发科强劲八核处理器&#xff0c;12nm制程工艺的记录仪具便是满足这些需求的理想选择。搭载4GB32GB内存&#xff0c;并运行Android 11.0操作系统&#xff0c;这款记录仪具展现出强劲的性能表现。 首先&#xff0c;这款记录仪具具备优秀的视频录制功能。它能完整…

mysql python学习笔记

mysql 基础概念 1.一个表格一般包含一个主建 2.可有多个主见,叫组合主见 3.可以有foreign key 用于链接外部表格的主建 外键目的&#xff1a; 这个约束的目的是确保当前表中的外键列&#xff08;JNO列&#xff09;的值必须存在于另一个表&#xff08;J’表&#xff09;的主键…

kibana7.17.7 将数据导出csv文件

配置kibana文件 首先先配置kibana.yaml内容如下&#xff0c;这里假设我的服务器ip地址为192.168.130.128&#xff0c;elasticsearch的ip地址为&#xff1a;192.168.130.129:9200&#xff0c;192.168.130.130:9200&#xff1a; server.host: "192.168.130.128" serv…

【踩坑专栏】追根溯源,从Linux磁盘爆满排查故障:mycat2与navicat不兼容导致日志暴增

昨天遇到了一个比较奇怪的问题&#xff0c;就是在挂起虚拟机的时候&#xff0c;虚拟机提示我XX脚本正在运行&#xff0c;很奇怪&#xff0c;我没有运行脚本&#xff0c;为什么会提示我这个呢。今天恢复虚拟机&#xff0c;也提示了一下脚本的问题&#xff0c;而且发现Linux明显异…

尚硅谷Java数据结构--希尔排序

插入排序的问题&#x1f388;&#xff1a; arr{2,3,4,5,6,0,9,7,8}; 当0作为插入元素的时候&#xff0c;其待插入下标与原下标相差很远&#xff0c;需要进行多次比较和移动。 希尔排序则是先将下标相差一定距离gap的元素分为一组&#xff0c;进行插入排序&#xff1b;再逐渐将距…