【发布时间】:2015-07-21 15:23:56
【问题描述】:
我已经看到很多类加载器问题,但仍然无法弄清楚为什么,这里的错误。
我正在编写一个使用 2 个版本的 jar 的程序。一个用于从旧存储中获取内容,另一个用于将内容存储在新存储中。
因为我需要一次加载其中一个 jar,所以我使用 JarClassLoader 创建了一个代理来添加一个 jar 并加载它的类。但我面临 ClassNotFoundException。
public class HbaseMigrator implements Runnable {
public void run() {
JarClassLoader jcl = new JarClassLoader();
jcl.add("hadoop-0.13.0-core-modified-1.jar");
Object obj1 = JclObjectFactory.getInstance().create(jcl, "UserMigThreadImpl", toProcessQueue,threadName, latch,DBUtil,lock);
MigThread mig = JclUtils.cast(obj1, MigThread.class, jcl);
Thread.currentThread().setContextClassLoader(jcl);
try {
Method method = MigThread.class.getMethod("callthis", new Class[]{});
method.invoke(mig, new Object[]{});
// mig.callthis();
} catch( Exception e) {
e.printStackTrace();
} catch(Error er) {
er.printStackTrace();
}
}
}
调用的方法是:
public void callthis() {
DFSUtil = new DFSAccessAPIImpl();
.........
}
这个类实例化在内部使用 hadoop 修改的 jar,它不是从我的类加载器中获取的,它会抛出 ClassNotFoundException。
我做错了什么?
这里使用的 JarClassLoader 是 jcloader : org.xeustechnologies.jcl.JarClassLoader
【问题讨论】:
-
检查使用的 ClassLoader:Class.getClassLoader() 在不同的点和不同的类以验证它是您使用的类加载器。
-
@Mr_Thorynque : UserMigThreadImpl.class.getClassLoader() 显示原始父类加载器及其类,而不是我刚刚创建的新类加载器。如何解决这个问题?
-
为了解决此类问题,创建了 OSGI。所以正确的解决方案是在 OSGI 容器中运行......我知道这个解决方案对你来说可能不现实。
-
为什么在创建 UserMigThreadImpl 对象后在 currentThread 中设置新的 jcl?为什么不使用基本的 java.lang.ClassLoader ?
标签: java classloader