初学JDBC请教基础问题

问题:
String URL="jdbc:mysql://localhost:3306/db_name";     
String Username="username";   
String Password="password";   
Class.forName("com.mysql.jdbc.Driver");
中 class是类,怎么可以直接调用方法forName
方法forName是返回com.mysql.jdbc.Driver的类对象吗?

Connection con=DriverManager.getConnection(URL,Username,Password); 
其中DriverManager是实现了接口的对象还是类?  接口的引用con可以指向是实现接口的对象

 

我的解答为:

    既然楼主对原理感兴趣,我就详细说一下:

Class.forName( )静态方法的目的是为了动态加载类。在加载完成后,一般还要调用Class下的newInstance( )静态方法来实例化对象以便操作。因此,单单使用Class.forName( )是动态加载类是没有用的,其最终目的是为了实例化对象。

 

 这里有必要提一下就是Class下的newInstance()和new有什么区别?,首先,newInstance( )是一个方法,而new是一个关键字,其次,Class下的newInstance()的使用有局限,因为它生成对象只能调用无参的构造函数,而使用new关键字生成对象没有这个限制。

 

Class.forName("")返回的是类
Class.forName("").newInstance()返回的是object

有数据库开发经验朋友会发现,为什么在我们加载数据库驱动包的时候有的却没有调用newInstance( )方法呢?
即有的jdbc连接数据库的写法里是Class.forName(xxx.xx.xx);而有一些:Class.forName(xxx.xx.xx).newInstance(),为什么会有这两种写法呢?
刚才提到,Class.forName("");的作用是要求JVM查找并加载指定的类,如果在类中有静态初始化器的话,JVM必然会执行该类的静态代码段。
而在JDBC规范中明确要求这个Driver类必须向DriverManager注册自己,即任何一个JDBC Driver的Driver类的代码都必须类似如下:
  public class MyJDBCDriver implements Driver {
    static {
      DriverManager.registerDriver(new MyJDBCDriver());
  }
  }
  既然在静态初始化器的中已经进行了注册,所以我们在使用JDBC时只需要Class.forName(XXX.XXX);就可以了。

Class.forName()问题应该解决了

 

 

 

首先说明:
DriverManager 是类

public class DriverManagerextends Object

DriverManager 类是 JDBC 的管理层,作用于用户和驱动程序之间。它跟踪可用的驱动程序,并在数据库和相应驱动程序之间建立连接。另外,DriverManager 类也处理诸如驱动程序登录时间限制及登录和跟踪消息的显示等事务。对于简单的应用程序,一般需要在此类中直接使用的唯一方法是 DriverManager.getConnection。正如名称所示,该方法将建立与数据库的连接。

你可能感兴趣的:(jvm,数据库,jdbc,String,object,Class)