exescope使用教程_exescope使用教程分享

exescope使用教程_exescope使用教程分享,第1张

exescope使用教程_exescope使用教程分享 依赖管理是maven提供的主要功能之一。

无论我们需要什么依赖,我们只需将它们添加到POM.xml中。

由于maven,所有必要的类和资源都会自动添加到项目的classpath中。

一、dependency依赖在POM 4中,<dependency>中还引入了<scope>,它主要管理依赖的部署。

目前<scope>可以使用5个值:* compile,缺省值,适用于所有阶段,会随着项目一起发布。

* provided,类似compile,期望JDK、容器或使用者会提供这个依赖。

如servlet.jar。

* runtime,只在运行时使用,如JDBC驱动,适用运行和测试阶段。

* test,只在测试时使用,用于编译和运行测试代码。

不会随项目发布。

* system,类似provided,需要显式提供包含依赖的jar,Maven不会在Repository中查找它。

下面看一个示例:<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-tomcat</artifactId><scope>provided</scope></dependency>二、scope参数取值项scope的值有以下几种可能,进行分情况讲解。

(1)compile默认就是compile,什么都不配置也就是意味着compile。

compile表示被依赖项目需要参与当前项目的编译,当然后续的测试,运行周期也参与其中,是一个比较强的依赖。

打包的时候通常需要包含进去。

默认的scope在部署的时候将会打包到lib目录下,项目在编译,测试,运行阶段都需要。

(2)testscope为test表示依赖项目仅仅参与测试相关的工作,在编译和运行环境下都不会被使用,更别说打包了。

(3)runntime仅仅适用于运行环境,在编译和测试环境下都不会被使用。

(4)provided适合在编译和测试的环境,和compile很接近,但是provided仅仅需要在编译和测试阶段,同样provide将不会被打包到lib目录下。

(5)system从参与度来说,也与provided相同,不过被依赖项不会从maven仓库抓,而是从本地文件系统拿,一定需要配合systemPath属性使用。

三、scope的依赖传递A–>B–>C。

当前项目为A,A依赖于B,B依赖于C。

知道B在A项目中的scope,那么怎么知道C在A中的scope呢?答案是:当C是test或者provided时,C直接被丢弃,A不依赖C;否则A依赖C,C的scope继承于B的scope。

为什么需要区分这些scope?可以用来限制dependency的范围可以在不同的环境下打包不同的jar包,比如junit测试类的jar包不需要在编译运行的时候,就可以设置scope为test。

四、<optional>true</optional>属性最后还有一个<optional>true</optional>是什么意思,怎么用的呢?<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><optional>true</optional></dependency>在添加依赖项时,我们可以使用optional熟悉,或将scope设置为“provided”。

在这两种情况下,依赖关系都将在声明它们的模块的classpath中,但是使用将它们定义为依赖关系的模块不会在其他项目中传递它们,即不会形成依赖传递。

例如上面的例子,在SpringBoot官网文件中你可以得到解释就是,<optional>true</optional>的话,其他项目依赖此项目也不会进行传递,只能本项目使用。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/tougao/665232.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-18
下一篇 2022-04-18

发表评论

登录后才能评论

评论列表(0条)

保存