我对这两个类加载器非常困惑。在谈到Java类加载器的层次结构时,通常会提到引导类加载器和ext类加载器以及第三个(系统类加载器或应用程序类加载器)。
为了更准确,我检查了JDK的源代码。在课程Launcher
中,有代码:
loader = AppClassLoader.getAppClassLoader(extcl);
在课程ClassLoader
中,方法:
getSystemClassloader()
还说系统类加载器用于启动应用程序。
那么哪个是层次结构中的第三个,还是两个类加载器相同?
答案 0 :(得分:8)
AppClassLoader
和SystemClassLoader
都相同。
看看层次结构。
ClassLoader遵循三个原则。
授权原则
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"的引导加载程序混淆。 类。