• 双亲委派模型


    双亲委派模型是java类加载器所使用的模型.

    双亲委派模型的工作过程:如果一个类加载器收到了类加载器的请求.它首先不会自己去尝试加载这个类.而是把这个请求委派给父加载器去完成.每个层次的类加载器都是如此.

    因此所有的加载请求最终都会传送到Bootstrap类加载器(启动类加载器)中.只有父类加载反馈自己无法加载这个请求(它的搜索范围中没有找到所需的类)时.子加载器才会尝试自

    己去加载.

    双亲委派模型执行流程:

     

    双亲委派模型的好处:java类随着它的加载器一起具备了一种带有优先级的层次关系.

    例如类java.lang.Object,它存放在rt.jart之中.无论哪一个类加载器都要加载这个类.最终都是双亲委派模型最顶端的Bootstrap类加载器去加载.因此Object类在程序的各种类加载器环境中都是同一个类.相反.如果没有使用双亲委派模型.由各个类加载器自行去加载的话.如果用户编写了一个称为“java.lang.Object”的类.并存放在程序的ClassPath中.那系统中将会出现多个不同的Object类.java类型体系中最基础的行为也就无法保证.应用程序也将会一片混乱.

    双亲委派的代码实现(在ClassLoader类中的loadClass中):

    protected synchronized Class<?> loadClass(String name,boolean resolve)throws ClassNotFoundException
    {
            Class c = findLoadedClass(name);
            if(c==null)
            {
                try
                {
                    if(parent!=null)
                    {
                        c = parent.loadClass(name,false);
                    }
                    else
                    {
                        c = findBootstrapClassOrNull(name);
                    }
                }
                catch(ClassNotFoundException e)
                {
                    
                }
                if(c==null)
                {
                    c = findClass(name);
                }
            }
            if(resolve)
            {
                resolveClass(c);
            }
            return c;
    }

    逻辑:先检查是否已经被加载过.若没有加载则调用父加载器的loadClass()方法.若父加载器为空则默认使用Bootstrap类加载器作为父加载器.若父加载失败.抛出ClassNotFoundException异常后再调用自己的findClass()方法进行加载...

  • 相关阅读:
    react 组件传值
    vue 子组件如何修改父组件data中的值??????????????????
    移动端的一些初始化 css 样式。。。
    centos7命令
    poi导出
    eclipse项目导入工作空间提示已存在问题
    maven jar包冲突问题
    layui下拉框渲染问题,以及回显问题
    两个线程交替运行——使用synchronized+wait+notify实现
    造成索引失效的情况
  • 原文地址:https://www.cnblogs.com/novalist/p/6409111.html
Copyright © 2020-2023  润新知