JAVA文件不是可执行性文件。因此运行JAVA程序需要加载(Load)相应的class文件,它包含了JAVA虚拟机(JVM)可识别的指令,JVM解析指令并执行相关操作。
每个.class文件都有一个相应名字的Class Object与之对应(例:自行车.class 则代表了一个名为自行车类型的对象)。当我们需要(执行)此对象时,ClassLoader就会通过这个自行车.class文件所对应的Class Object名字(自行车)去查找与之对应的自行车.class文件。这也是JAVA语言的定义-----解析执行语言。
ClassLoader:
负责加载执行程序所需的文件(资源)。此处讨论的ClassLoader是实现自定义的类加载策略,有关JVM自带的ClassLoader(如JAVA核心类的加栽、环境变量所代表路径上的类加载)参考相关文章。
java.lang.ClassLoader
protected synchronized Class<?> loadClass(String name, boolean resolve) throws ClassNotFoundException
{
// First, check if the class has already been loaded
Class c = findLoadedClass(name);
if (c == null) {
try {
if (parent != null) {
c = parent.loadClass(name, false);
} else {
c = findBootstrapClass0(name);
}
} catch (ClassNotFoundException e) {
// If still not found, then invoke findClass in order
// to find the class.
c = findClass(name);
}
}
if (resolve) {
resolveClass(c);
}
return c;
}
{
// First, check if the class has already been loaded
Class c = findLoadedClass(name);
if (c == null) {
try {
if (parent != null) {
c = parent.loadClass(name, false);
} else {
c = findBootstrapClass0(name);
}
} catch (ClassNotFoundException e) {
// If still not found, then invoke findClass in order
// to find the class.
c = findClass(name);
}
}
if (resolve) {
resolveClass(c);
}
return c;
}
1.检查当前加载的类是否已经被加载
findLoadedClass(name) != null ? 简单返回JVM中已加载的类 : 第2步 ;
(以下2、3引出JVM类加载模式。2、3的存在是因JVM具体实现(安全方面)。感兴趣的朋友可以花点时间查看有关文档。了解一些有关这些方面的细节有助更好的理解与学习掌握JAVA。本人不是很懂,希望大家常来作客,交流。)
2.判断parentClassLoader是否存在 不存在则执行第3步 否则使用它来加载并返回
parentClassLoader != null ? 由parentClassLoader加载当前类 : 第3步
3.如果boottClassLoader存在,则使用它来加载,否则执行第4步
4.使用自定义实现ClassLoader的子类去加载
因此在实现自定义的类加载策略时,只需在子类中重写findClass()方法
转载于:https://blog.51cto.com/460293/92815