深入理解java虚拟机---双亲委派模型

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

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

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

己去加载.

双亲委派模型执行流程:

深入理解java虚拟机---双亲委派模型_第1张图片


双亲委派模型的好处: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虚拟机)