jdeps

JDeps是Java依赖关系分析工具 ,这是一个命令行工具,它处理Java字节码(意味着.class文件或包含它们的JAR),并分析类之间静态声明的依赖关系。 可以用各种方式过滤结果,并可以将其汇总到包或JAR级别。 JDeps还可以告诉您您的项目正在使用哪些JDK内部API,并且完全了解模块系统 。 总而言之,它是检查各种形式的依赖图的非常有用的工具。

在这篇文章中,我将向您介绍JDeps的工作方式-后续文章将向您展示一些很好的用例。 对于此探索,我鼓励您继续进行,最好是执行您的一个项目。 如果您有一个项目的JAR,并且在它旁边是一个包含所有传递依赖项的文件夹,这将是最容易的。 如果您使用的是Maven,则可以通过maven-dependency-plugin的copy-dependencies目标实现后者。 使用Gradle,您可以使用复制任务,从设置为configuration.compile或configuration.runtime 。

作为示例项目,我选择了Scaffold Hunter :

Scaffold Hunter是基于Java的开源工具,用于对数据集进行可视化分析,重点是生命科学中的数据,旨在直观地访问大型和复杂的数据集。 该工具提供多种视图,例如图形,树状图和图解视图,以及分析方法,例如用于聚类和分类

我下载了2.6.3版本的ZIP,并将所有依赖项都复制到了libs中。

当显示输出时,我将scaffoldhunter(在软件包名称中)和scaffold-hunter(在文件名称中)缩写为sh以使其更短。

认识JDeps

从Java 8开始,您就可以在JDK的bin文件夹中找到JDeps可执行文件jdeps。如果在命令行上可以找到JDeps可执行文件jdeps,则最容易使用它,对此您可能必须执行一些特定于操作系统的设置步骤。 确保jdeps –version可以正常工作并显示Java 9版本正在运行。

下一步是获取JAR并将JDeps设置为宽松。 在不使用其他命令行选项的情况下使用,它将首先列出代码所依赖的JDK模块。 紧随其后的是软件包级别的依赖关系列表,其组织为<package>-> <package> <module / JAR>。

调用jdeps sh-2.6.3.jar会得到以下输出:

$ jdeps sh-2.6.3.jarsh-2.6.3.jar -> java.base
sh-2.6.3.jar -> java.datatransfer
sh-2.6.3.jar -> java.desktop
sh-2.6.3.jar -> java.logging
sh-2.6.3.jar -> java.prefs
sh-2.6.3.jar -> java.sql
sh-2.6.3.jar -> java.xml
sh-2.6.3.jar -> not foundedu.udo.sh -> com.beust.jcommander  not foundedu.udo.sh -> edu.udo.sh.data       sh-2.6.3.jaredu.udo.sh -> edu.udo.sh.gui        sh-2.6.3.jaredu.udo.sh -> edu.udo.sh.gui.util   sh-2.6.3.jaredu.udo.sh -> edu.udo.sh.util       sh-2.6.3.jaredu.udo.sh -> java.io               java.baseedu.udo.sh -> java.lang             java.baseedu.udo.sh -> javax.swing           java.desktopedu.udo.sh -> org.slf4j             not found
[... truncated many more package dependencies ...]

您可以看到Scaffold Hunter依赖于模块java.base (当然), java.desktop (这是一个Swing应用程序), java.sql (数据集存储在SQL数据库中)以及其他一些模块。 这之后是一长串的软件包依赖项,这有点麻烦。请注意,有些依赖项被标记为未找到,这很有意义,因为我没有告诉JDeps在哪里寻找它们。

现在是时候使用各种选项来配置JDeps了。 您可以使用jdeps -h列出它们。

包括依赖项

JDeps的一个重要方面是,它使您可以像分析代码一样将其依赖性进行分析。 达到该目标的第一步是使用–class-path将它们放到类路径中。

这使JDeps可以遵循进入依赖项JAR的路径,并使您摆脱未找到的指标。 要实际分析依赖关系,还需要使用-recursive或-R将JDeps递归到它们。

为了包括Scaffold Hunter的依赖关系,我使用–class-path'libs / *'和-recursive执行JDeps:

$ jdeps --class-path 'libs/*' -recursive sh-2.6.3.jar[... truncated split package warnings ...]
[... truncated some module/JAR dependencies...]
sh-2.6.3.jar -> libs/commons-codec-1.6.jar
sh-2.6.3.jar -> libs/commons-io-2.4.jar
sh-2.6.3.jar -> libs/dom4j-1.6.1.jar
sh-2.6.3.jar -> libs/exp4j-0.1.38.jar
sh-2.6.3.jar -> libs/guava-18.0.jar
sh-2.6.3.jar -> libs/heaps-2.0.jar
sh-2.6.3.jar -> libs/hibernate-core-4.3.6.Final.jar
sh-2.6.3.jar -> java.base
sh-2.6.3.jar -> java.datatransfer
sh-2.6.3.jar -> java.desktop
sh-2.6.3.jar -> java.logging
sh-2.6.3.jar -> java.prefs
sh-2.6.3.jar -> java.sql
sh-2.6.3.jar -> java.xml
sh-2.6.3.jar -> libs/javassist-3.18.1-GA.jar
sh-2.6.3.jar -> libs/jcommander-1.35.jar
[... truncated more module/JAR dependencies...]edu.udo.sh -> com.beust.jcommander  jcommander-1.35.jaredu.udo.sh -> edu.udo.sh.data       sh-2.6.3.jaredu.udo.sh -> edu.udo.sh.gui        sh-2.6.3.jaredu.udo.sh -> edu.udo.sh.gui.util   sh-2.6.3.jaredu.udo.sh -> edu.udo.sh.util       sh-2.6.3.jaredu.udo.sh -> java.io               java.baseedu.udo.sh -> java.lang             java.baseedu.udo.sh -> javax.swing           java.desktopedu.udo.sh -> org.slf4j             slf4j-api-1.7.5.jar
[... truncated many, many more package dependencies ...]

在这种特定情况下,输出以一些拆分程序包警告开头,我现在将忽略它们。 以下模块/ JAR和程序包的依赖关系与以前类似,但现在都可以找到,因此它们的数量更多。 但是,这会使输出变得更加压倒一切,因此现在该是时候探讨如何从如此大量的数据中弄清楚了。

配置JDeps的输出

有多种方法可以配置JDeps的输出。 也许在任何项目的第一次分析中使用的最佳选择是-summary或​​-s,它们仅显示JAR之间的依赖关系,而忽略包的依赖关系。 下表列出了各种其他方式来获取有关依赖关系的不同观点:

选项 描述
–package或-p 其次是只考虑该包,这是看哪里使用这些utils的所有地方一个伟大的方式依赖包名。
–regex或-e 后跟一个正则表达式,它仅考虑与正则表达式匹配的类的依赖。
(请注意,除非使用-verbose:class,否则输出仍会显示包。)
-filter或-f 后跟一个正则表达式,它排除对与正则表达式匹配的类的依赖。
(请注意,除非使用-verbose:class,否则输出仍会显示包。)
-filter:存档 在许多情况下,工件的依赖性不是那么有趣。
该选项将忽略它们,仅显示工件的依赖性。
–仅API 有时,尤其是在分析库时,您只关心JAR API。
使用此选项,仅检查公共签名和公共类的受保护成员的签名中提到的类型。

命令行上的输出是检查细节并深入研究有趣的位的好方法。 但是,它并不能提供最直观的概述-图表要好得多。 幸运的是,JDeps具有–dot-output选项,该选项可为每个单独的分析创建.dot文件 。 这些文件是纯文本,但是可以使用其他工具(例如Graphviz)从它们创建图像。

这两个命令产生下图:

$ jdeps --class-path 'libs/*' -recursive --dot-output dots sh-2.6.3.jar
$ dot -Tpng -O dots/summary.dot

深钻

如果您想了解更多细节,-verbose:class将列出类之间的依赖关系,而不是将它们聚合到包级别。

有时,仅列出对程序包或类的直接依赖关系是不够的,因为它们可能实际上不在您的代码中,而是在您的依赖关系中。 在这种情况下,-inverse或-I可能会有所帮助。 给定要查找的特定程序包或正则表达式,它会一直跟踪依赖关系,并在此过程中列出工件。 不幸的是,似乎没有直接方法可以在类级别而不是工件上查看结果。

在您的特定情况下,还有其他一些选项可能会对您有所帮助–如前所述,您可以使用jdeps -h列出它们。

JDeps和模块

就像借助模块系统一样,编译器和JVM可以在更高的抽象级别上运行 ,JDeps也可以。 可以使用–module-path指定模块路径(请注意-p已经保留,因此它不是此选项的简写形式),而初始模块可以使用–module或-m指定。 从那里,我们上面所做的分析可以完全相同。

因为Scaffold Hunter尚未模块化,所以我将切换到我的书中使用的关于Java 9模块系统的示例项目Monitor应用程序 。 在这里,我正在创建模块关系的摘要分析:

# on `master` branch
$ jdeps --module-path mods:libs -m monitor -summary -recursive[... truncated some module dependencies...]
monitor -> java.base
monitor -> monitor.observer
monitor -> monitor.observer.alpha
monitor -> monitor.observer.beta
monitor -> monitor.persistence
monitor -> monitor.rest
monitor -> monitor.statistics
monitor.observer -> java.base
monitor.observer.alpha -> java.base
monitor.observer.alpha -> monitor.observer
monitor.observer.beta -> java.base
monitor.observer.beta -> monitor.observer
monitor.persistence -> java.base
monitor.persistence -> monitor.statistics
monitor.rest -> java.base
monitor.rest -> monitor.statistics
monitor.rest -> spark.core
monitor.statistics -> java.base
monitor.statistics -> monitor.observer
slf4j.api -> java.base
slf4j.api -> not found
spark.core -> JDK removed internal API
spark.core -> java.base
spark.core -> javax.servlet.api
spark.core -> jetty.server
spark.core -> jetty.servlet
spark.core -> jetty.util
spark.core -> slf4j.api
spark.core -> websocket.api
spark.core -> websocket.server
spark.core -> websocket.servlet
[... truncated more module dependencies...]

除此之外,还有一些Java 9和特定于模块的选项。 使用–require <modules>,您可以列出所有需要命名模块的模块。 您可以使用–jdk-internals分析项目的问题依赖关系,以及–generate-module-info或–generate-open-module创建模块描述符的初稿。 正如前面提到的,JDeps还将始终报告其找到的所有拆分包。

在以后的文章中,我将向您展示如何使用这些标志来帮助您的项目进行模块化。

获取我的书,并了解有关如何在Java 9迁移中使用JDeps的更多信息!
Java 9模块系统

  • 模块系统的深入介绍:

    • 基本概念和高级主题
  • 曼宁(Manning)发布:
    • 自2017年赛事开始提供抢先体验
  • 订阅我的时事通讯以保持关注。
    (甚至可以偷看。)

使用代码fccparlog可获得 37%的折扣

反射

使用JDeps,您可以分析项目的静态声明的依赖关系。 它在类级别上运行,但是将结果汇总到包和工件级别。 使用各种过滤器,您可以专注于最重要的方面。 也许最基本的分析是跨代码和第三方库的工件依赖关系图:

$ jdeps --class-path 'libs/*' -summary -recursive sh-2.6.3.jar

它可用于执行一些非常有趣的分析,尤其是在较大的代码库上。 我将很快为您展示一些示例。

翻译自: https://www.javacodegeeks.com/2017/07/jdeps-primer-analyzing-projects-dependencies.html

jdeps

jdeps_JDeps入门–分析项目的依赖关系相关推荐

  1. JDeps入门–分析项目的依赖关系

    JDeps是Java依赖关系分析工具 ,这是一个命令行工具,它处理Java字节码(意味着.class文件或包含它们的JAR),并分析类之间静态声明的依赖关系. 可以用各种方式过滤结果,并可以将其汇总到 ...

  2. structure101_使用structure101分析软件包的依赖关系

    structure101 稳定应用程序的一个关键是结构良好的代码库. 我们知道我们应该建立尽可能多的黑匣子,因为一旦完成一个黑匣子,我们就不必再考虑其内部了. 您只需要使用您或其他团队成员通过明确定义 ...

  3. 使用structure101分析软件包的依赖关系

    稳定应用程序的一个关键是结构良好的代码库. 我们知道我们应该建立尽可能多的黑匣子,因为一旦完成一个黑匣子,我们就不必再考虑它的内部了. 您只需要使用您或其他团队成员通过明确定义的界面编写的代码即可. ...

  4. 正在读取软件包列表... 完成 正在分析软件包的依赖关系树 正在读取状态信息... 完成 有一些软件包无法被安装。如果您用的是 unstable 发行版,这也许是 因为系统

    解决办法一 sudo apt-get update sudo apt-get upgrade 一般这样就ok 了 还不行换个源 ,也就是说当前这个源没有这个包,换个源,推荐华为源,是我目前试过最快的, ...

  5. Repo Jacking:依赖关系仓库劫持漏洞,影响谷歌GitHub等7万多个开源项目的供应链...

     聚焦源代码安全,网罗国内外最新资讯! 编译:奇安信代码卫士团队 三个场景可导致 GitHub 仓库遭劫持.直接组合使用这三个场景可导致恶意代码注入.千万别这么做. 背景 最近的一个客户项目使我们开始 ...

  6. Unity5.x 依赖关系打包 AssetBundle 研究

    Unity5.x新依赖打包及加载 https://blog.csdn.net/strugglebydreamlin/article/details/78031086 demo:https://pan. ...

  7. Unity打包AssetBundle自动分析资源依赖关系(包括UGUI图集打包)

    https://blog.csdn.net/u012740992/article/details/79371986 怎么分析资源的依赖关系呢,并设置AssetBundleName呢? 我们检测资源之间 ...

  8. Ubuntu上安装gtk2.0不能安装的问题,“下列的软件包有不能满足的依赖关系”

    zez@localhoss:~$ sudo apt-get install libgtk2.0-dev 正在读取软件包列表... 完成 正在分析软件包的依赖关系树        正在读取状态信息... ...

  9. 排除jar_Gradle排除依赖关系

    Gradle排除依赖关系 在IDE中发现了C3P0的依赖,但是在build.gradle并没有手动导入,所以说某个jar包依赖了,在STS中没有像Maven可以直接查看依赖的窗口 可以在命令行下查看整 ...

最新文章

  1. 《小岛经济学--鱼、美元和经济的故事》Digest
  2. build.xml java打包_配置pom.xml用maven打包java工程的方法(推荐)
  3. CenOS6.5安全加固及性能优化(脚本)
  4. Android•Lottie动画库填坑记
  5. 如何用ASPxGridView绑定多表关联的查询结果
  6. mysql-explain
  7. babel 用法及其 .babelrc 的配置详解,想做前端架构,拒绝一知半解...
  8. 二次元福利适应个人引导页
  9. linux 常识笔记 20160621
  10. PAT甲级 1003 Dijkstra的口诀干货
  11. nginx利用try_files实现多个源
  12. php解决中文乱码的函数,php 中解决json中文乱码的函数_PHP教程
  13. 怎样控制小程序tabbar图标大小_微信小程序tabBar的基本设置-微信小程序tabbar字体大小-微信小程序tabbar高度...
  14. eclipse的优缺点
  15. ps如何保存透明图片
  16. avi格式视频转换高清mp4的方法
  17. python热图_python – 使用matplotlib中的3D数据生成热图
  18. c语言二级证题库及详解答案,全国计算机等级考试二级C语言上机题库及其答案详解...
  19. 从源码出发,会源码,懂源码
  20. java date.getdate_java – 获取昨天 – 不推荐使用Date类型的方法getDate()

热门文章

  1. jzoj5699-[GDOI2018day1]涛涛接苹果【树套树】
  2. P2414-[NOI2011]阿狸的打字机【AC自动机,树状数组】
  3. jzoj6296-投票【期望dp,贪心】
  4. jzoj4802-[GDOI2017模拟9.24]探险计划【费用流,拆点】
  5. Sentinel(十五)之在生产环境中使用 Sentinel
  6. Spring Cloud面试题(2020最新版)
  7. 面试进阶之字符串常量池
  8. Java中的OutOfMemoryError
  9. Maven精选系列--标准目录结构
  10. Java高级篇——深入浅出Java类加载机制