您的位置:首页 > 数据库 > MySQL

为什么jdbc链接时 只要class.forname("com.mysql.jdbc.Driver")即可?

2017-06-08 10:13 696 查看
以前都是照本宣科,网上怎么写链接MySQL 就抄过来。。今天觉得无聊,自己看了看mysql driver的源码类。具体了解下其工作原理:

首先class.forname(String className) 这个方法会调用相应的class进行类初始化,一般在Java中如果初始化一个类,我们需要对这个类进行实例化,也就是new class()方法。反射也提供这一方式:class.forClass(classname).newInstance(),
这样会初始化一个无参的构造函数。 那么这样是不是初始化jdbc时应写成:

class.forname("com.mysql.jdbc.Driver").newInstance() ?

测试这样写,是OK的。但是为什么class.forname("com.mysql.jdbc.Driver") 不实例化对象也可以使用?

其主要原因就是在驱动类中,
Java doc中任何一个驱动类都需要implements Driver 并且在static 方法中去,注册driver到 driverManager。

 com.mysql.jdbc.Driver 的源码:

[java]
view plain
copy

public class Driver extends NonRegisteringDriver implements java.sql.Driver {  
    public Driver() throws SQLException {  
    }  
  
    static {  
        try {  
            DriverManager.registerDriver(new Driver());  
        } catch (SQLException var1) {  
            throw new RuntimeException("Can\'t register driver!");  
        }  
    }  
}  

他在JVM加载类的时候就会执行static方法,该方法会对DriverManager注册,指定类的对象。所以,其实我们写class.forName时,真正操作的是类中static方法(且该方法在jvm中加载后就不在重复加载,一次即可),去创建了一个链接的对象供我们未来使用。

以后别写class.forname("com.mysql.jdbc.Driver").newInstance() 啦~。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: