Idea查看源代码警告Library source does not match the bytecode for class XXX解决办法

背景

执行代码的时候抛出异常,想在第三方jar文件中打断点分析问题原因,进入该文件后IDEA给出警告
在这里插入图片描述
翻译过来就是资源库的源代码与类的字节码不匹配,当前我们在UpgraderManager.java中,右侧有一个Open.class file按钮,点击之后就会跳转到UpgradeManager.class中,点击show diff或者对比这两个文件可以看到是不一样的。

这个问题影响还是挺大的,具体的现象就是程序真正运行的代码行数,与我们看到的代码行数不一致,也就没法打断点分析程序的走向

分析

我们在使用第三方jar时,用的是编译好的字节码文件,即.class文件,而不是源文件.java。而.class文件我们是看不懂的,如果我们想在IDE中看第三方源代码,可以通过IDE的插件进行自动反编译,但是一般来说不会有注释,而且参数名也不是原来的参数名,会被反编译成var1, var2, var3等。
Idea查看源代码警告Library source does not match the bytecode for class XXX解决办法_第1张图片

当然也可以自己下载源文件后进行配置。

一般来说第三方jar在打包时也会将源文件和class文件一起发布,所以引用这个jar时IDE会自动引用它的源文件,可以通过如下方式进行查看
以IDEA为例,点击File->Project Structure..
Idea查看源代码警告Library source does not match the bytecode for class XXX解决办法_第2张图片
在弹出的窗口中选择Library菜单,中间的窗口部分选中包含警告文件的jar,在右侧可以看到Classes字节码,Sources源代码以及JavaDocsjava文档对应的jar
Idea查看源代码警告Library source does not match the bytecode for class XXX解决办法_第3张图片
到这里可以分析出,警告的内容就是说xxx.jar中内容与xxx-source.jar中的内容不一致,进入到该文件夹中继续进行查看
Idea查看源代码警告Library source does not match the bytecode for class XXX解决办法_第4张图片
虽然jar与source.jar的版本一致,但是修改的日期不一样,也就是说由于某种原因导致了jar与source.jar里边的内容不一致了,使用解压软件进行查看里边的某些文件也会发现,有些代码在source.jar中存在但是在jar中却不存在

解决办法

知道了问题原因,那么就知道怎么解决了。
很简单,将该版本中的所有jar全部删除,重新用maven下载
本例中就需要将xxx.2.1.0这个文件夹全部删除,然后在IDEA中使用maven reload project(旧版本为maven reimport)重新下载该jar,或者自行去maven仓库网站下载亦可。下载之后再查看该文件,就没有警告了,断点就可以继续打了。

你可能感兴趣的:(jar,idea)