为什么 eclipse 和 cmd 运行 jar,运行的类不一致?

2020-12-09 20:01:07 +08:00
 miaeLKK

https://imgchr.com/i/rPib9g 如图,eclipse 调试,程序跑到了 AppenderAction 类,然后我把这个工程打成 jar,在 jar 包里删除了这个 class,jar 包仍然运行? cmd 和 eclipse 云的是同一个 jre,为了排除 jvm 类缓存问题我也重启电脑了,为什么呢?

1658 次点击
所在节点    Java
3 条回复
miaeLKK
2020-12-09 20:01:38 +08:00
今天在调试一个问题,用的 logback+slf4j,为一个普通 java 项目添加日志,在 eclipse 中执行,会有日志在工作空间那个项目里,打成 jar 包就找不到了,为了找到 jar 包的日志,我开始调试,找到日志文件位置字符串后重新编译 logback 下的 class 并添加控制台输出,可我发现 eclipse 控制台输出了,但 jar 包在 cmd 中仍然没有输出,难道没走这个类?我尝试删了 jar 包中的那个 class,jar 包居然还能运行??怎么回事呢?
miaeLKK
2020-12-09 20:01:48 +08:00
另外我还发现,jar 包里使用接口,执行时的实现类在 cmd 和 eclipse 中不一样,这个不知道是不是不同版本 jdk 导致的,后来我已经使用同一个 jdk 了,但时发现这个类都不进入了。。
pursuer
2020-12-09 21:02:13 +08:00
要把 eclipse 和 cmd 的执行命令写出来才能查,查 classpath

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/733882

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX