双亲委派源码分析

简介: 双亲委派源码分析

说明

双亲委派其实字面上面翻译成双亲,但是其实多个类加载器之间没有继承关系,看源码其实只是一个递归调用的过程。

类加载的精髓解释

在类加载的方案其实主要的目的是为了保证版本的一致性,直观点的例子就是,如果我们自己去定义一个类库中已有的类的话,其实不会被执行,举例说明:

//我们自己去定义这么一个对象
public class String {
    public static void main(String[] args) {
        System.out.println("String");
    }
}

编译,执行

javac String.java
java String

结果如下:

错误: 找不到或无法加载主类 String

事实上在我们的idea上面也是没办法去运行的,这个情况其实是在jvm优先加载了我们类库中的类,类加载的时候优先加载了内部的类,另外定义的名字一样的类就不会被加载了。这样子的好好处其实就是保证了jdk自己写的类不会被覆盖,保护了原有的代码。

双亲委派的代码如下,我做了注释:

 protected Class<?> loadClass(String name, boolean resolve)
        throws ClassNotFoundException
    {
        synchronized (getClassLoadingLock(name)) {
            // First, check if the class has already been loaded
            //检查该类是否已经类加载
            Class<?> c = findLoadedClass(name);
            if (c == null) {
                long t0 = System.nanoTime();
                try {
                
                //有上级的话,就委托上级去进行加载,递归方式去加载
                    if (parent != null) {
                        c = parent.loadClass(name, false);
                    } else {
                    //没有上级了ExtClassloader,则委派BootstrapClassload加载
                        c = findBootstrapClassOrNull(name);
                    }
                } catch (ClassNotFoundException e) {
                    // ClassNotFoundException thrown if class not found
                    // from the non-null parent class loader
                }

                if (c == null) {
                    // If still not found, then invoke findClass in order
                    // to find the class.
                    //每一层都找不到,则调用findclass方法进行加载(每个类加载器自己扩展)
                    long t1 = System.nanoTime();
                    c = findClass(name);

                    // this is the defining class loader; record the stats
//记录耗时                    sun.misc.PerfCounter.getParentDelegationTime().addTime(t1 - t0);
                    sun.misc.PerfCounter.getFindClassTime().addElapsedTimeFrom(t1);
                    sun.misc.PerfCounter.getFindClasses().increment();
                }
            }
            if (resolve) {
                resolveClass(c);
            }
            return c;
        }
    }


目录
相关文章
|
7月前
|
存储 Java 编译器
类加载机制和双亲委派机制
类加载机制和双亲委派机制
|
1月前
|
Java
类加载器和双亲委派机制
从父类加载器到子类加载器分别为: BootStrapClassLoader 加载路径为:JAVA_HOME/jre/lib ExtensionClassLoader 加载路径为:JAVA_HOME/jre/lib/ext ApplicationClassLoader 加载路径为:classpath 还有一个自定义类加载器
|
4月前
|
Java 编译器
什么是双亲委派机制?
什么是双亲委派机制?
262 59
|
4月前
|
前端开发 Java C++
双亲委派机制
这篇文章详细解释了Java中的双亲委派机制,包括其原理、类加载器的分类(启动类加载器、扩展类加载器、应用程序类加载器)以及它们之间的关系和作用。
|
存储 缓存 安全
JVM面试专题-双亲委派机制(父类委托机制)
JVM面试专题-什么是双亲委派机制(父类委托机制)?如何打破双亲委派机制?双亲委派机制的优缺点?什么是沙箱安全机制呢?
208 1
|
7月前
|
前端开发 Java API
JVM 类加载器 双亲委派机制
【1月更文挑战第3天】JVM 类加载器 双亲委派机制
|
前端开发 安全 Java
双亲委派到底是个啥
双亲委派到底是个啥
43 0
|
前端开发 Java
05-说下类加载器和双亲委派机制
在明白了整个类从加载到初始化的过程,接下来我们有必要来说下类加载器的概念,因为实现上述过程是必须依靠加载器来实现的。
72 0
05-说下类加载器和双亲委派机制
|
缓存 Java API
双亲委派机制是什么?
如果跟同事谈“双亲委派”,难免显得很八股了,但是这个“双亲委派”却是JVM在类加载环节必不可少的一个操作,充分的理解它,能够使我们更加良好的理解JVM在加载类的时候背后细节。不仅如此,在学习了解一些其他的技术,例如:SPI、OSGI等等,也能相辅相成,融会贯通,可谓“两仪生四象,四象生八卦”
220 1
双亲委派机制是什么?
|
安全 Java 应用服务中间件
浅谈双亲委派机制
经典八股文之双亲委派模型
169 0