本文主要是介绍(转)IDEA的Maven Show Dependency使用心得,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
【原文地址:https://blog.csdn.net/daerzei/article/details/82344569】
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/daerzei/article/details/82344569
在Idea Indexing和resolve Dependency的时候是不能查看Show Dependency的。
你就算只引一个包它也会有依赖冲突,
Alt加鼠标可以放大看,但是Alt放开的时候放大镜有时候并不会消失,这个时候可以继续按Alt键,鼠标移动到空白的地方待放大镜消失再松开Alt镜
红色实线表示有jar包依赖冲突,一般是版本冲突。点击冲突的jar包,IDEA会把所有引用到这个jar包的地方再以红色虚线连接起来,并高亮连接线。不点的话红色虚线是不显示出来的。
我这边做测试只引了一个jar包spark-hive_2.11
,这个jar包直接依赖的是spark-sql,spark-core,hive-exec,hive-metastore这是第一级依赖,第二级依赖:hadoop-common,hadoop-hdfs,hadoop-annotations竺,然后层层依赖,最后依赖到最底层的jar包,比如说apache-commons-(io/lang/lang3/beanutils/codec),guava,scala-(library/compiler/p/),log4j等等。于是Maven又自动把这些依赖的jar包引了进来。
虽然只引了这么一个jar包,但是依然有jar包依赖冲突,比如说有的jar包依赖于Scala2.11.8
与有的jar包依赖于Scala2.11.7
。
如果这些冲突的jar包API没有变的话是没有影响的, 但是如果API变的话那就有影响了,比如说guava18.0
以后有些API就发生了变化,这个时候就不得不降低guava
的版本了。
右键点击exclude
可以把这个有冲突的jar包排除掉
IDEA会自动同步更新pom.xml
配置文件。
不过IDEA的show Depentency搞耗性能的,如果你电脑配置不怎么样的话这么搞可能不管用,这个时候就需要你手动排除了,在pom.xml配置文件对应的依赖包里加上如下配置:
<exclusions><exclusion><groupId>org.scala-lang</groupId><artifactId>scala-library</artifactId></exclusion>
</exclusions>
- 1
- 2
- 3
- 4
- 5
- 6
再回到Show Dependency视图,会自动更新的。
不要老想着把那些红线排除掉,排除不完的,可能我有些代码洁癖吧,看到这些红色就觉得浑身不爽,花了三天的时候把它们排除掉,最后头都搞大了,红线还是不少。
这篇关于(转)IDEA的Maven Show Dependency使用心得的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!