关于Thread.currentThread().setContextClassLoader 10C

问题点:
public static void main(String[] args) throws Exception {
Thread.currentThread().setContextClassLoader(customClsLoader);
System.out.println(Thread.currentThread().getContextClassLoader());
System.out.println(TestBean.class.getClassLoader());
//打印出来的结果是AppClassLoader并不是我预期的自定义的classloader
}

TestBean 是main类的一个同包的类,我设置了classloader为自定义类加载器,但是为什么实际上他还是用系统自带的AppClassLoader加载了呢。 那设置当前线程的类加载器到底有什么用呢。

请高手帮忙解答下,谢谢啦。

1个回答

 首先,你这段代码不全,customClsLoader的定义看不到,如果有效,这句代码只会影响当前现线程的classLoader的打印。
其次,TestBean这个类还是由默认的类加载器加载的,除非你手动调用你自定义的classLoader的loadClass方法加载TestBean,否则它跟你前面的设置是没有关系的,它在你调用打印之前已经被默认类加载器加载完成了。
例如: Class classDate = new MyClassLoader("class_temp").loadClass("ClassLoaderAttachment");  
参考连接:http://blog.csdn.net/jiangwei0910410003/article/details/17733153
gentleduo
gentleduo 我的理解:setContextClassLoader只是在当前上下文(即:当前线程)定义了一个上下文类加载器,在不显示的调用这个上下文加载器的时候,所有类还是遵循JVM的类加载原则(即:双亲委托)。只有在想打破双亲委托原则的时候才使用此上下文加载器。并不是说setContextClassLoader完之后,接下来所有的类都由自定义的类加载器加载
3 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐