JDBC是如何打破双亲委派模式的

yJDBC是如何打破双亲委派模式的 - 掘金为什么JDBC需要打破双亲委派机制 JDBC的DriverManager与SPI机制 类加载的机制以及双亲委派机制的介绍可以参考 JVM类加载机制 在JDBC 4.0之后,我们不再需要调用Class.https://juejin.cn/post/7007292903361871903为什么JDBC需要打破双亲委派机制 JDBC的DriverManager与SPI机制 类加载的机制以及双亲委派机制的介绍可以参考 JVM类加载机制 在JDBC 4.0之后,我们不再需要调用Class.https://juejin.cn/post/7007292903361871903

为什么JDBC需要打破双亲委派机制

JDBC的DriverManager与SPI机制


类加载的机制以及双亲委派机制的介绍可以参考 JVM类加载机制

在JDBC 4.0之后,我们不再需要调用Class.forName()方法去加载驱动类。只需要将对应的驱动类jar包放到工程的class path下,驱动类会自动被加载。

这种自动加载的技术被称为SPI(Service Privider Interface)[3],SPI可以简单理解为:为了解耦,从配置里获取某个接口的具体实现类。各个数据库也都更新支持了这个特性。包括MySQL-JDBC等,每个JDBC的jar包里都有一个META-INF/services 目录,里面有一个 java.sql.Driver 文件,里面指定了这个driver的实现类的全限定名。

DriverManager的类加载问题


类加载的范围受到限制,某些情况下父class loader无法加载某些类文件,这时候就需要委托到下层级的class loader去加载类文件。

JDBC的driver接口定义在JDK中,但是它的实现类是放在classpath下的(比如MySQL)。

  • DriverManager类会加载每个Driver接口的实现类并管理它们,但是DriverManager类自身是 jre/lib/rt.jar 里的类,是由bootstrap classloader加载的
  • 根据类加载机制,某个类需要引用其它类的时候,虚拟机将会用这个类的classloader去加载被引用的类
  • boostrap classloader显然是无法加载到MySQL driver的(ClassNotFoundException)
  • 因此只能在DriverManager里强行指定下层classloader来加载Driver实现类,而这就会打破双亲委派模型

猜你喜欢

转载自blog.csdn.net/qq_39552268/article/details/121568444