scope在maven的依赖管理中主要负责项目的部署
maven中,很多内容都有默认值,scope的默认值是compile
scope的分类
1.compile:默认值 他表示被依赖项目需要参与当前项目的编译,还有后续的测试,运行周期也参与其中,是一个比较强的依赖。打包的时候通常需要包含进去,也就是整个周期都会参与
2.test:依赖项目仅仅参与测试相关的工作,包括测试代码的编译和执行,不会被打包,例如:junit
3.runtime:表示被依赖项目无需参与项目的编译,不过后期的测试和运行周期需要其参与。与compile相比,跳过了编译而已。例如JDBC驱动,适用运行和测试阶段
4.provided:打包的时候可以不用包进去,别的设施会提供。事实上该依赖理论上可以参与编译,测试,运行等周期。相当于compile,但是打包阶段做了exclude操作
5.system:从参与度来说,和provided相同,不过被依赖项不会从maven仓库下载,而是从本地文件系统拿。需要添加systemPath的属性来定义路径
scope的依赖传递
A依赖B,B依赖C。
当前项目为A,只当B在A项目中的scope,那么c在A中的scope是如何得知呢?
当C是test或者provided时,C直接被丢弃,A不依赖C;(排除传递依赖)
否则A依赖C,C的scope继承与B的scope
本文详细解析了Maven中依赖范围(scope)的概念,包括默认值、不同scope的含义及其在项目周期中的作用,如compile、test、runtime、provided和system。同时介绍了scope如何影响依赖的传递,帮助开发者更高效地管理项目依赖。
5万+

被折叠的 条评论
为什么被折叠?



