双亲委派 & URLClassLoader & SPI

本文介绍了Java中的ClassLoader和双亲委派机制,详细讲解了URLClassLoader的工作原理,包括loadClass和findClass方法。接着探讨了SPI(Service Provider Interface)服务发现机制,解释了为何BootstrapClassLoader和ExtClassLoader无法加载MySQL驱动,并通过ServiceLoader的使用展示了SPI的实现原理。文章最后提到了ServiceLoader的使用步骤和SPI的应用实例。
  • ClassLoader & 双亲委派
  • URLClassLoader
  • SPI(Service Provider Interface)

ClassLoader & 双亲委派

ClassLoader 编程语言 加载内容 Parent ClassLoader
BootstrapClassLoader C++ jre/lib;jre/classes Null Java虚拟机启动后初始化
ExtClassLoader Java jre/lib/ext;java.ext.dirs BootstrapClassLoader
AppClassLoader Java classpath指定位置 ExtClassLoader ClassLoader.getSystemClassLoader 返回值

ClassLoader的基本模型:

Java默认ClassLoader委派模型
载录:https://www.cnblogs.com/doit8791/p/5820037.html

URLClassLoader

  • ClassLoader.loadClass
  • URLClassLoader.findClass
  • ExtClassLoader & AppClassLoader 的URLClassPath

ClassLoader.loadClass

    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) {
   
   
                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.
                    c = findClass(name);
                }
            }
            if (resolve) {
   
    resolveClass(c); }
            return c;
        }
    }

    // ClassLoader method
    protected Class<?> findClass(String name) throws ClassNotFoundException {
   
   
        throw new ClassNotFoundException(name);
    }

其中findClass是关键:一来没有具体实现,二来修饰符是protected,所以 很明显是为了“开闭”。

URLClassLoader.findClass

// URLClassLoader overwrite
    protected Class<?> findClass(final String name)
        throws ClassNotFoundException
    {
   
   
        final Class<?> result;
        try {
   
   
            result = AccessController.doPrivileged(
                new PrivilegedExceptionAction<Class<?>>() {
   
   
                    public Class<?> run() throws ClassNotFoundException {
   
   
                        String path = name.replace('.', '/').concat(".class");
                        Resource res = ucp.getResource(path, false)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值