AppClassloader和SystemClassloader之间的区别

时间:2016-01-07 08:37:57

标签: java classloader

我对这两个类加载器非常困惑。在谈到Java类加载器的层次结构时,通常会提到引导类加载器和ext类加载器以及第三个(系统类加载器或应用程序类加载器)。

为了更准确,我检查了JDK的源代码。在课程Launcher中,有代码:

loader = AppClassLoader.getAppClassLoader(extcl);

在课程ClassLoader中,方法:

getSystemClassloader() 

还说系统类加载器用于启动应用程序。

那么哪个是层次结构中的第三个,还是两个类加载器相同?

3 个答案:

答案 0 :(得分:8)

AppClassLoaderSystemClassLoader都相同。

看看层次结构。

ClassLoader遵循三个原则。

授权原则

ClassLoader hieraechy

Bootstrap ClassLoader负责从rt.jar加载标准JDK类文件,它是Java中所有类加载器的父级。 Bootstrap类加载器没有任何父母。

Extension ClassLoader将类加载请求委托给其父,Bootstrap,如果不成功,则加载类表单jre / lib / ext目录或java.ext.dirs系统属性指向的任何其他目录

System or Application class loader它负责从CLASSPATH环境变量,-classpath或-cp命令行选项,JAR中的Manifest文件的Class-Path属性加载特定于应用程序的类。

应用程序类加载器是Extension ClassLoader的子项,由sun.misc.Launcher$AppClassLoader类实现。

Bootstrap class loader以外,主要用C语言实现,所有Java类加载器都是使用java.lang.ClassLoader实现的。

看看这个blog,以便更好地理解这三个类加载器。

可见性原则

  

根据可见性原则, Child ClassLoader 可以看到由 Parent ClassLoader but vice-versa is not true加载的类。

如果类{Ab}被Application class loader加载,那么尝试使用Extension ClassLoader显式加载ABC类将抛出java.lang.ClassNotFoundException

唯一性原则

  

根据这个原则,父类加载的类不应再次由Child ClassLoader加载

答案 1 :(得分:1)

类加载器层次结构中的第三个是SystemClassloader。它在某些地方也称为ApplicationClassloader(或AppClassLoader)。这个加载器加载我们在类路径中找到的应用程序代码和类。

关于Classloader中的以下方法:

  

public static ClassLoader getSystemClassLoader()

Javadoc说:

  

返回用于委派的系统类加载器。这是默认值   新的ClassLoader实例的委托父级,通常是   用于启动应用程序的类加载器。

这里重要的一点是

  

这是新的ClassLoader实例的默认委托父级,通常是用于启动应用程序的类加载器

这意味着,如果我们在应用程序中创建自己的自定义或新类加载器,则系统或应用程序类加载器将成为自定义或新类加载器的父级。在自定义或新的类加载器中调用getSystemClassLoader()方法将返回System(aka Application)类加载器。这也与java类加载器委托模型一致。

System(aka Application)类加载器是从类路径加载我们的类或app的那个。

答案 2 :(得分:1)

系统类加载器是Application类加载器的另一个名称。

来源: https://blogs.oracle.com/sundararajan/entry/understanding_java_class_loading

  

应用程序类加载器......也(混乱地)被称为"系统类   装载机" - 不要与加载Java" system"的引导加载程序混淆。   类。