请教关于类加载器报 NoClassDefFoundError 错误的几点疑问(附详细代码)

2022-02-25 17:25:51 +08:00
 linuxsteam

问题代码

URL[] urls = new URL[6];
urls[0] = '/activation-1.1.1.jar'
urls[1] = '/animal-sniffer-annotations-1.14.jar'
urls[2] = '/annotations-16.0.2.jar'
urls[3] = '/antlr-runtime-3.4.jar'
urls[4] = '/asm-4.2.jar'
urls[5] = '/cglib-3.1.jar'
URLClassLoader urlCLassLoader = new URLClassLoader(urls);
try
{
    // 将全部存储到 urlclassload 里面
    for (String fullClassName : allFullClassNames)
    {
        if (!"module-info".equals(fullClassName))
        {
            Class<?> clazz = urlCLassLoader.loadClass(fullClassName);
            System.out.println(fullClassName);
        }
    }
}
catch (Exception e)
{
    e.printStackTrace();
}

报错前的日志打印

https://paste.ubuntu.org.cn/4545513

net.sf.cglib.transform.AbstractClassTransformer 反编译代码

//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by FernFlower decompiler)
//

package net.sf.cglib.transform;

import org.objectweb.asm.ClassVisitor;

public abstract class AbstractClassTransformer extends ClassTransformer {
    protected AbstractClassTransformer() {
        super(262144);
    }

    public void setTarget(ClassVisitor target) {
        this.cv = target;
    }
}

AppClassLoader 中没有加载 asm-4.2.jar 与 cglib-3.1.jar 中的类,其他的都有加载过了

上述 jar 包下载地址(无需下载客户端)

https://www.123pan.com/s/dCH9-LYAAA 提取码:v2ex

现在针对以上代码小弟有几个问题:

Class<?> clazz = urlCLassLoader.loadClass("net.sf.cglib.transform.AbstractClassTransformer"); 小弟进入断点后看到这行执行会报错 java.lang.NoClassDefFoundError: org/apache/tools/ant/Task

这个 NoClassDefFoundError 报错的问题,我在<深入理解 Java 虚拟机:JVM 高级特性与最佳实践(第 3 版)周志明>中找到了原因 大概是 类加载过程解析步骤 出现了 符号引用转为直接引用找不到的问题

但是还是有以下疑问

  1. org/apache/tools/ant/Task 在类 net.sf.cglib.transform.AbstractClassTransformer 中没有看到任何符号引用,不知道为何会找这个类
  2. 假设:asm-4.2.jar 引用了 cglib-3.1.jar 中的类,那么是不是在加载 asm-4.2.jar 所有类的时候就会报错 NoClassDefFoundError ?
1094 次点击
所在节点    Java
3 条回复
Jooooooooo
2022-02-25 17:28:08 +08:00
NoClassDefFoundError 绝大多数都是两个不同的 jar 里有相同的路径, 然后加载类的时候找错了.

排除一下就行.
linuxsteam
2022-02-25 17:52:29 +08:00
关于第一个问题
我又查了下资料
https://mvnrepository.com/artifact/cglib/cglib/3.3.0
上述连接中是描述 cglib 依赖于 org.apache.ant » ant 的
但是该 jar 包 META-INF/中是没有 maven 这个文件夹的。自然我就发现他下面依赖的 org.apache.ant » ant 。。。
看来我又得研究研究 jar 包的元数据信息了
linuxsteam
2022-02-25 17:54:07 +08:00
@linuxsteam 但是 org.apache.ant » ant 是可选的。。。我又迷糊了。。。

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

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

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

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

© 2021 V2EX