我对班级装载机有几个问题。
Class.forName("class.name");
和
....
NotYetLoadedClass cls = new NotYetLoadedClass();
.....
每种情况下将使用哪些类加载器?对于第一种情况,我假设用于加载方法代码正在执行的类的类加载器。在第二种情况下,我假设线程上下文类加载器。
如果我错了,我会赞赏一个小小的解释。
答案 0 :(得分:2)
两者都使用当前的ClassLoader
。正如DNA正确指出的那样,http://docs.oracle.com/javase/6/docs/api/java/lang/Class.html#forName%28java.lang.String%29表明Class.forName()
使用当前的类加载器。一个小实验表明,使用new
语句加载实例化的类也使用当前ClassLoader
:
public class Test
{
public static void main(String[] args) throws Exception
{
Thread.currentThread().setContextClassLoader(new MyClassLoader());
SomeClass someClass = new SomeClass();
someClass.printClassLoader();
}
public static class MyClassLoader extends ClassLoader
{
public MyClassLoader()
{
super();
}
public MyClassLoader(ClassLoader parent)
{
super(parent);
}
}
}
public class SomeClass
{
public void printClassLoader()
{
System.out.println(this.getClass().getClassLoader());
System.out.println(Thread.currentThread().getContextClassLoader());
}
}
在Test
中,我们将当前的线程ContextClassLoader设置为某个自定义ClassLoader
,然后实例化类SomeClass
的对象。在SomeClass
中,我们打印出当前线程的ContextClassLoader和加载此对象类的ClassLoader
。结果是
sun.misc.Launcher$AppClassLoader@3326b249
test.Test$MyClassLoader@3d4b7453
表示当前ClassLoader
(sun.misc.Launcher.AppClassLoader
)用于加载课程。