7- Maven配置文件Scope解释

在添加依赖的时候有时候会看到有着样的写法,比平常的多了scope参数

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>3.8.1</version>
    <scope>test</scope>
</dependency>

下面来解释一下scope参数

Scope

Maven中的scope有compile、test、runtime、provided、system,其中默认的值是compile。

Compile

默认就是compile,什么都不配置也就是意味着compile。compile表示被依赖项目需要参与当前项目的编译,当然后续的测试,运行周期也参与其中,是一个比较强的依赖。打包的时候通常需要包含进去。

Test

scope为test表示依赖项目仅仅参与测试相关的工作,包括测试代码的编译,执行。比较典型的如junit。

junit只有在执行单元测试时候需要,当我们进行真正项目发布的时候junit是不需要进行编译和发布的。

runtime

runtime表示被依赖项目无需参与项目的编译,不过后期的测试和运行周期需要其参与。与compile相比,跳过编译而已,说实话在终端的项目(非开源,企业内部系统)中,和compile区别不是很大。举例说明一下:在代码中调用了一个接口一个方法,这个接口并没有对应的实现。这段代码在编译期间并不会报错,但是在代码运行的时候会出现问题。jdbc驱动可以使用runtime的scope,因为只有在真正运行的时候才会调用到驱动的代码。

provided

provided意味着打包的时候可以不用包进去,别的设施(Web Container)会提供。事实上该依赖理论上可以参与编译,测试,运行等周期。相当于compile,但是在打包阶段做了exclude的动作。
比如:

<dependency>  
         <groupId>javax.servlet</groupId>  
          <artifactId>servlet-api</artifactId>  
            <version>2.5</version>  
            <scope>provided</scope>  
        </dependency>  
        <dependency>  
            <groupId>javax.servlet.jsp</groupId>  
            <artifactId>jsp-api</artifactId>  
            <version>2.1</version>  
            <scope>provided</scope>  
        </dependency>  

tomcat会提供这个servlet-api.jar 包,所以当我们项目发布的时候这个包是不需要打到包里的

system

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

Scope的依赖传递

目前的前提是项目 A依赖多个jar包
然后项目C依赖项目A。

依赖传递

图片中最左边一列 表示 项目C的pom.xml依赖项目A的scope;
最上面一行表示 项目A依赖jar包的scope;


下面的代码是项目A对jar包的依赖,包含test、compile、provided、runtime多个scope类型

<dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>
        
        <dependency>
            <groupId>jstl</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>

        <dependency>
            <groupId>taglibs</groupId>
            <artifactId>standard</artifactId>
            <version>1.1.2</version>
            <scope>provided</scope>
        </dependency>
        
        <!-- mysql jdbc -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.9</version>
            <scope>runtime</scope>
        </dependency>
    </dependencies>

下面我们将要讨论的是,当项目C对项目A的依赖scope发生变化的时候,项目C的传递依赖和依赖scope发生的变化

<dependency>
      <groupId>com.zhou</groupId>
      <artifactId>mavenTest</artifactId>
      <version>0.0.1-SNAPSHOT</version>
      <scope>${scope}</scope>
</dependency>
  1. 项目C对项目A的scope为compile
compile

传递依赖只有compile的jstl和runtime的mysql,而且scope和A项目pom中配置的scope一致。

  1. 项目C对项目A的scope为test
test

同样只有compile和runtime的包,可以传递依赖。而且传递依赖的scope都被设置为test

  1. 项目C对项目A的scope为provided
provided

只有compile和runtime的包,依赖的scope被设置为provided

  1. 项目C对项目A的scope为runtime
runtime

同样compile 和runtime的包。而且传递依赖的scope都被设置为了runtime

经过上面的测试我们发现

如果 项目A对B的依赖的scope是test 或者provided,那么项目C依赖的A的时候,不管对A的依赖scope是什么,都是会出现传递依赖。
反之,当A对B的依赖是runtime或者compile,不管项目C对A的依赖是什么scope,都会出现传递依赖。传递依赖的scope的规则是,如果C项目对A的依赖是compile,那么传递依赖scope和项目A对B的依赖scope相同,否则和C对A的依赖scope保持一致。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,014评论 19 139
  • maven项目中需要使用到其它依赖时,则需要在pom.xml中配置<dependency>元素也就是依赖声明,这样...
    zlcook阅读 1,865评论 1 3
  • 逛了个小公园,回来理发,晚上看了个电影《我的少女时代》,又打了一盘lol,然后就没刷题了
    健时总向乱中忙阅读 129评论 0 0
  • 下载youku视频列表 直接使用you-get先用you-get -il http://list.youku.co...
    璀璨星空阅读 6,565评论 1 1
  • 深秋的季节,配上了湿答答的雨天,又恰逢周末,本应当是用来睡觉的时候,可是有一帮人,选择了2天1夜的职业动力...
    胡永群阅读 590评论 0 49