1700447892
1700447893
Class.forName(“com.mysql.jdbc.Driver”);
1700447894
1700447895
String url=“jdbc:mysql://localhost:3306/db?user=&password=”;
1700447896
1700447897
Connection conn=DriverManager.getConnection(url);
1700447898
1700447899
Statement stmt=conn.createStatement();
1700447900
1700447901
……
1700447902
1700447903
在没有Hibernate和Ibatis等ORM框架的情况下,基本上每个系统都会有这么一个JDBC连接类,然后提供诸如Query、Delete等的方法,大家有没有想过为什么要加上forName这句话呢?没有任何的输出呀,要它干什么用呢?事实上非常有用,我们看一下Driver类的源码:
1700447904
1700447905
public class Driver extends NonRegisteringDriver implements java.sql.Driver{
1700447906
1700447907
//静态代码块
1700447908
1700447909
static{
1700447910
1700447911
try{
1700447912
1700447913
//把自己注册到DriverManager中
1700447914
1700447915
java.sql.DriverManager.registerDriver(new Driver());
1700447916
1700447917
}catch(SQLException E){
1700447918
1700447919
//异常处理
1700447920
1700447921
}
1700447922
1700447923
}
1700447924
1700447925
//构造函数
1700447926
1700447927
public Driver()throws SQLException{
1700447928
1700447929
}
1700447930
1700447931
}
1700447932
1700447933
该程序的逻辑是这样的:数据库的驱动程序已经由NonRegisteringDriver实现了,Driver类只是负责把自己注册到DriverManager中。当程序动态加载该驱动时,也就是执行到Class.forName(“com.mysql.jdbc.Driver”)时,Driver类会被加载到内存中,于是static代码块开始执行,也就是把自己注册到DriverManager中。
1700447934
1700447935
需要说明的是,forName只是把一个类加载到内存中,并不保证由此产生一个实例对象,也不会执行任何方法,之所以会初始化static代码,那是由类加载机制所决定的,而不是forName方法决定的。也就是说,如果没有static属性或static代码块,forName就只是加载类,没有任何的执行行为。
1700447936
1700447937
注意 forName只是加载类,并不执行任何代码。
1700447938
1700447939
1700447940
1700447941
[
上一页 ]
[ :1.700447892e+09 ]
[
下一页 ]