Maven debug关联源码配置

本文介绍了解决Maven项目中因未绑定依赖源码而引起的Sourcenotfound问题的方法。一种是手动添加依赖源码,另一种是通过sourcelookup插件自动配置。后者更为简便高效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

引出

Maven的出现为开发Java应用程序提供了便利的依赖管理工具,以及大量的插件支持。但在实际使用中,无论是debug项目中自定义依赖模块的代码,还是第三方依赖,经常会遇到Source not found.的问题。这是由于没有绑定依赖源码导致。

2523457-9f214867805c7bbf.png
Source not found

解决办法

1 手动添加依赖的源码

之前的解决办法是在配置maven命令时,手动将依赖的maven模块添加到Source下。

2523457-0ed26bbda3f35ac4.png
maven configuration

毕竟自定义项目模块有限,添加起来比较简单。但是一旦需要添加第三方依赖的源码时,那就是件比较头疼的事了,而且多为无用功。

2523457-c717a04f61584e81.png
maven configuration

这种方式虽说能解决Source not found.的问题,但是操作过于繁琐,不推荐使用(那是因为找到了更好的办法_)。

2 使用sourcelookup插件

这里推荐一款sourcelookup插件,地址:https://bjmi.github.io/update-site,使用eclipse在线安装该插件。

2523457-914e3875a41c098e.png
install plugin

安装完成后,就能够再Maven配置窗口的Source Tab窗口下找到Maven Dependencies的选项。只要将依赖的项目模块添加进去即可。

2523457-f0a0aae10f89605d.png
maven configuration

添加完成后,就能够看到其所有的依赖了,包括依赖的模块和第三方库。

2523457-b8a599f792210ae6.png
maven configuration

当然,要想添加第三方依赖的源码,首先应确保本地maven仓库中有该依赖的源码。

### 解决 IntelliJ IDEA 调试时源码不可见的方法 当遇到IntelliJ IDEA调试过程中无法查看源码的情况,这可能是由于几个原因造成的。为了确保能够顺利地在调试期间访问到所需的源文件,建议按照以下方法逐一排查并解决问题。 #### 配置项目依赖库的源码路径 如果正在尝试调试的是第三方库,则需要确认这些库已经正确配置了对应的源码包。可以通过Maven或Gradle构建工具自动下载相应的源码附件,或者手动指定本地存储的源代码位置[^2]。 对于通过Maven管理项目的场景,在`pom.xml`中加入如下配置可让IDEA自动获取远程仓库中的源码: ```xml <build> <plugins> <!-- ... --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-surefire-plugin</artifactId> <version>${surefire.version}</version> <configuration> <useFile>false</useFile> </configuration> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-source-plugin</artifactId> <executions> <execution> <id>attach-sources</id> <goals> <goal>jar-no-fork</goal> </goals> </execution> </executions> </plugin> </plugins> </build> <repositories> <repository> <id>jcenter</id> <url>https://jcenter.bintray.com/</url> </repository> </repositories> ``` 而对于Gradle用户来说,只需简单修改`build.gradle`即可实现相同效果: ```groovy dependencies { implementation 'com.example:some-library:1.0' testImplementation('com.example:some-test-lib:1.0') { changing = true } } // 自动下载依赖项及其源码 allprojects { afterEvaluate { project -> configurations.all*.resolvedConfiguration.resolvedArtifacts.each { artifact -> if (project.configurations.findByName("source") != null && !new File("${rootDir}/libs/${artifact.moduleVersion.id.group.replace('.','-')}-${artifact.moduleVersion.name}-sources.jar").exists()) { ant.get(src: "${artifact.moduleVersion.id.url}", dest: "libs", usetimestamp: false) } } } } ``` 完成上述操作之后重新加载项目结构(`Reload All Maven Projects`),此时应该可以看到所使用的外部库已关联上其官方发布的源码版本。 #### 设置正确的断点条件与过滤器 有时即使成功附加了源码但仍可能因为某些特定条件下触发不到预期的断点而感觉像是“看不见”源码一样。这时应当仔细检查设置好的断点是否有误或是被其他全局性的忽略规则影响到了正常工作状态。例如,默认情况下IntelliJ IDEA会在Debug模式下暂停所有线程执行直到当前调试点结束;但如果希望允许其他非关键业务逻辑继续异步处理的话就需要调整这一行为设置了[^3]。 前往菜单栏选择【Run】-> 【View Breakpoints...】,在这里可以根据实际需求灵活设定各类不同类型的中断机制(如行级、异常捕获等),同时还可以针对具体类名甚至表达式创建精准匹配式的监视点。更重要的是记得勾选下方提供的选项——“Suspend”,将其改为仅挂起单一线程而非整个应用程序实例,从而减少不必要的干扰因素妨碍正常的阅读体验。 另外值得注意的一点是在多模块复杂工程环境下可能会存在多个同名函数定义的情形,因此务必保证每次打断都指向最合适的那个目标对象之上。利用快捷键Ctrl+B(Windows/Linux)/Cmd+B(MacOS)快速跳转至声明处不失为一种高效的做法。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值