1.Java | 带你理解 ServiceLoader 的原理与设计思想
2.Class.forName
3.javajdbc连接sqlserver的时候,不需要写class.forname
Java | 带你理解 ServiceLoader 的原理与设计思想
本文将为您解析Java中ServiceLoader的原理与设计思想,以JDBC为例,引导您理解和掌握其基本用法与内部机制。
首先,了解JDBC的五大步骤,包括定义服务接口、java语言项目源码实现服务接口、注册实现类到配置文件、加载服务。
定义服务接口时,JDBC通过抽象一个服务接口,使数据库驱动实现类统一实现此接口,实现代码耦合的马特源码降低。
接着,实现服务接口,数据库厂商提供一个或多个实现此服务的类,如MySQL的com.mysql.cj.jdbc.Driver。
注册实现类到配置文件,需在java同级目录下的震刀源码resources/META-INF/services新建文件,每行记录实现类全限定名,方便ServiceLoader查找。
加载服务时,DriverManager的静态代码块通过ServiceLoader遍历所有驱动实现类,此过程无需实际操作。
深入ServiceLoader源码解析,硬盘杀手源码其构造器创建LazyIterator实例,此迭代器采用懒加载策略,优先从providers集合获取元素。
providers集合是LazyIterator的内存缓存,LazyIterator#next()方法将每次迭代获取的元素放入此集合,实现高效检索。gnulibc源码包
ServiceLoader要点总结,包括构造器、迭代器及优先加载机制。
解决DriverManager源码疑问,为何next()操作不取得服务实现类对象?答案在于LazyIterator的高效设计,它在获取元素后立即放入缓存,无需额外操作。
在DriverManager中,注册服务实现类实例并保存在CopyOnWriteArrayList中,后续获取数据库连接时直接从该列表获取驱动。
ServiceLoader设计思想强调模块化与扩展性,通过懒加载机制提高性能,简化代码耦合。
本文仅提供基本概念与解析,后续将探讨ARouter与WMRouter的源码实现,欢迎关注彭旭锐的博客。
Class.forName
ä¸è¾¹æ¯mysql-connector-java-5.1.6-bin.jarçDriveræºä»£ç ï¼
----com.mysql.jdbc.Driver----------------------------------------------------
.package com.mysql.jdbc;
.import java.sql.SQLException;
.public class Driver extends NonRegisteringDriver implements java.sql.Driver {
. // ~ Static fields/initializers
. // ---------------------------------------------
. //
. // Register ourselves with the DriverManager
.//
. static {
. try {
. java.sql.DriverManager.registerDriver(new Driver());
. } catch (SQLException E) {
. throw new RuntimeException("Can't register driver!");
. }
. }
. public Driver() throws SQLException {
. // Required for Class.forName().newInstance()
. }
.}
------------------------------------------------------------------------
å ¶å®ï¼å¨Class.forName()çæ¶åç³»ç»ä¼æ§è¡å¨æå 载类çstaticåï¼ä¹å°±æ¯-è¡ï¼å ¶ä¸ç代ç æ¯åDriverManager注åMySQLçDriverï¼ç°å¨å¤§å®¶ç¥é为ä»ä¹è¦æ§è¡Class.forName()äºåï¼ï¼ï¼
ä¹å°±æConnection conn = DriverManager.getConnection("è¿æ¥å符串");äºã
javajdbc连接sqlserver的时候,不需要写class.forname
Java JDBC 连接 SQL Server 不需书写 class.forName 的原理在于高版本的 Oracle 和 MySQL 已采用最新 SPI 技术,驱动类名在 jar 包的 META-INF/services/java.sql.Driver 文件中定义。DriverManager 源码中的静态块 loadInitialDrivers() 显示,这行代码能加载类路径下所有 jar 包中 META-INF/services/java.sql.Driver 文件定义的类,此类需继承自 java.sql.Driver。Class.forName 的主要目的是初始化数据库驱动,执行驱动的静态块代码,其实质是 DriverManager.registerDriver(driver); 方法。由于开发者的明确配置,驱动包发布时已直接指定驱动名,因此无需再次书写 class.forName。