本篇内容介绍了“什么是双亲委派机制”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
公司主营业务:网站建设、成都做网站、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联建站是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联建站推出温岭免费做网站回馈大家。
- Bootstrap ClassLoader 启动类加载器 
- Extention ClassLoader 标准扩展类加载器 
- Application ClassLoader 应用类加载器 
- User ClassLoader 用户自定义类加载器 
 
 
 - Bootstrap ClassLoader ,主要负责加载Java核心类库,%JRE_HOME%\lib下的rt.jar、resources.jar、charsets.jar和class等。 
- Extention ClassLoader,主要负责加载目录%JRE_HOME%\lib\ext目录下的jar包和class文件。 
- Application ClassLoader ,主要负责加载当前应用的classpath下的所有类 
- User ClassLoader , 用户自定义的类加载器,可加载指定路径的class文件 
public abstract class ClassLoader {
        // The parent class loader for delegation
        private final ClassLoader parent;
    }
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 {
                            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.
                        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;
            }
        }
代码不难理解,主要就是以下几个步骤:
- loadClass() 就是主要进行类加载的方法,默认的双亲委派机制就实现在这个方法中。 
- findClass() 根据名称或位置加载.class字节码 
- definclass() 把字节码转化为Class 
/**
     * @since  1.2
     */
    protected Class> findClass(String name) throws ClassNotFoundException {
        throw new ClassNotFoundException(name);
    }
这个方法只抛出了一个异常,没有默认实现。
   
   
   Connection conn = DriverManager.getConnection("jdbc:MySQL://localhost:3306/mysql", "root", "1234");在以上代码执行之前,DriverManager会先被类加载器加载,因为java.sql.DriverManager类是位于rt.jar下面的 ,所以他会被根加载器加载。
ServiceLoaderloadedDrivers = ServiceLoader.load(Driver.class); 
这段代码,会尝试加载classpath下面的所有实现了Driver接口的实现类。
   
   
  public static  ServiceLoader load(Class service) {
        ClassLoader cl = Thread.currentThread().getContextClassLoader();
 
    
    
        return ServiceLoader.load(service, cl);
    }
   
   
   第一行,获取当前线程的线程上下⽂类加载器 AppClassLoader,⽤于加载 classpath 中的具体实现类。
 
 
 Class> c = findLoadedClass(cn);
    if (c == null) {
        // 找到当前类属于哪个模块
        LoadedModule loadedModule = findLoadedModule(cn);
        if (loadedModule != null) {
            //获取当前模块的类加载器
            BuiltinClassLoader loader = loadedModule.loader();
            //进行类加载
            c = findClassInModuleOrNull(loadedModule, cn);
         } else {
              // 找不到模块信息才会进行双亲委派
                if (parent != null) {
                  c = parent.loadClassOrNull(cn);
                }
          }
    }
“什么是双亲委派机制”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!
当前文章:什么是双亲委派机制
链接地址:http://www.scyingshan.cn/article/gseeoc.html

 建站
建站
 咨询
咨询 售后
售后
 建站咨询
建站咨询 
 