前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Maven学习笔记四(坐标和依赖)

Maven学习笔记四(坐标和依赖)

作者头像
IT架构圈
发布2018-06-01 11:26:36
5690
发布2018-06-01 11:26:36
举报
文章被收录于专栏:IT架构圈
坐标

什么是坐标? 在平面几何中坐标(x,y)可以标识平面中唯一的一点

Maven 坐标主要组成

groupId:定义当前 Maven 项目隶属项目、组织

artifactId:定义实际项目中的一个模块

version:定义当前项目的当前版本

packaging:定义该项目的打包方式(pom/jar/war,默认为 jar)

groupId、artifactId、version 简称为 GAV。

Maven 为什么使用坐标?

Maven 世界拥有大量构件,需要找一个用来唯一标识一个构建的统一规范 拥有了统一规范,就可以把查找工作交给机器

如何获取坐标 http://mvnrepository.com/ 网站上可以搜索具体的组织或项目关键字,之后复制 对应的坐标到 pom.xml 中。如:

依赖

依赖范围 scope 用来控制依赖和编译,测试,运行的 classpath 的关系。具 体的依赖范围有如下 6 种:

1) compile: 编译域,这个是 Maven 中 scope 的默认值,我们平时不写 scpoe 配置时默认就是使用这个值。compile 表示被依赖项目需要同当前项目编译 时一起进行编译,项目测试期以及本项目运行时期同样生效,打包的时候需 要包含进去。

2) test:测试域,表示被依赖的项目仅在项目进行测试的时候生效,一般将日 志等依赖包(如:Junit)配置为 test,项目运行时不会生效。

3) provided:provided 意味着打包的时候可以不用打包进去,别的容器会提供, 如 Servlet-API,Tomcat 这些容器会提供,所以打包,运行时无需提供。

4) runtime:运行域,表示被依赖项目不会参与项目的编译,但项目的测试期和 运行时期会参与。与 compile 相比,跳过了编译这个环节。(如:JDBC 驱动)

5) system:系统范围,自定义构件,指定 systemPath;跟 provided 相似,但是 在系统中要以外部 JAR 包的形式提供,maven 不会在 repository 查找它。

6) import:只使用在中,表示从其它的 pom 中导入 dependency 的配置。

添加依赖

依赖的传递

A(maven_web1)项目,B(maven_web2)项目 ,C(maven_test2)项目

首先A项目中添加依赖包,保存后项目中会自动导入包

然后A项目的包传递到B项目中,在B项目中依赖:

c项目中依赖B项目的包(因为B也依赖了A项目的包,因此C会依赖A,B项目的包):

说明:

可选依赖

在依赖节点 dependency 中的可以控制当前的依赖是否向下传递; 默认值为 false,表示向下传递。

设置log4j<optional>true</optional>

B项目中log4j包已经没有中A中传递过来

排除依赖

在 pom 中的依赖节点中,如果引入的依赖包含了很多其它的传递依赖,而且 项目需要的这些依赖的版本和传递依赖的不相符;那么可以在依赖节点中设置排 除依赖节点

B项目进行排除依赖,C项目也不接收A中传递给B的依赖

依赖冲突

1.不同依赖路径的情况

如果依赖的路径不相同的时候,以最短的路径为准

比如项目A中咯log4j版本为1.2.14,我们在B中引入1.2.16,那么项目C就会变成1.2.16,就近原则。

2.相同依赖路径的情况

1)如果直接依赖中包含有同一个坐标不同版本的资源依赖,以配置顺序下方的 版本为准

2)如果间接依赖中包含有同一个坐标不同版本的资源依赖,以配置顺序上方的 版本为准

首先我们就导入spring-beans这个资源

然后2个资源依赖一起引用,spring-core版本变成了4.1.6

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-03-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 编程坑太多 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档