zoukankan      html  css  js  c++  java
  • 双亲委派模型

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

    重点:

    1.向上查找,查找缓存,查找缓存中是否加载过该类;

    2.向下查找,查找加载路径,在指定路径中加载类。

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

    因此所有的加载请求最终都会传送到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()方法进行加载...
     

    团队五人,专业从事软件开发,接单工作,专注于Java,.Net,PHP
  • 相关阅读:
    【原创】编程题练习:反转字符串中的单词
    【最近的学习安排】
    【转载】判断两个链表是否相交、一个链表是否有环
    获取字符串字节长度
    如何找到GridView里的控件,建立GridViewRow对象
    Flex和.NET协同开发利器FluorineFx Flex与.NET互操作
    两款基于Visual Studio开发Flex的插件
    Mysql:向信号量添加给定计数将导致其超出它的最大计数错误
    Sql Server数据库触发器实例
    国外一些知名ASP.Net开源CMS系统
  • 原文地址:https://www.cnblogs.com/xiaohouye/p/14626547.html
Copyright © 2011-2022 走看看