`
snail_fish
  • 浏览: 33171 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Class.forName("XXXX")

    博客分类:
  • Java
阅读更多

    在Java开发特别是数据库开发中,经常会用到Class.forName( )这个方法。通常也不知其含义,通过查询Java Documentation我们会发现使用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);就可以了。

 

相关英文参考文献如下:
we just want to load the driver to jvm only, but not need to user the instance of driver, so call Class.forName(xxx.xx.xx) is enough, if you call Class.forName(xxx.xx.xx).newInstance(), the result will same as calling Class.forName(xxx.xx.xx), because Class.forName(xxx.xx.xx).newInstance() will load driver first, and then create instance, but the instacne you will never use in usual, so you need not to create it.

     显然上面的一段话说明Class.forName()只是加载了类,并没有创建类的实例,要创建类的实例还是需要调用.newInstance()方法的。

     下面给出一个例子大家来参考:

package test.classforname;

class A {
	void aa(){
		System.out.println("AAAAAAAAAAAAAAAAAAAAAAAA");
	}
}
class B extends A{
//	public B(String name){
//		System.out.println("B构造");
//	}
	void aa(){
		System.out.println("BBBBBBBBBBBBBBBBBBBBBBBBBB");
	}
}
class C extends A {
//	public C(String name){
//		System.out.println("C构造");
//	}
	void aa(){
		System.out.println("CCCCCCCCCCCCCCCCCCCCCCCCCC");
	}
}
public class ClassForNameTest {

	void showName(String name){
		try {
			A xx = (A) Class.forName(name).newInstance();
			xx.aa();
		} catch (InstantiationException e) {
			e.printStackTrace();
		} catch (IllegalAccessException e) {
			e.printStackTrace();
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
	}
	public static void main(String[] args) {
		ClassForNameTest ct = new ClassForNameTest();
		ct.showName("test.classforname.B");
	}
}

 

  

分享到:
评论

相关推荐

    java 数据库连接 sql access oracle mysql

    这里的关键是`Class.forName`方法用于加载Oracle的JDBC驱动程序,`DriverManager.getConnection`用于建立数据库连接。 ### 连接SQL Server数据库 对于SQL Server数据库,连接方式也类似: ```java Class.forName...

    java + 动态代理 + 动态代理实际应用场景

    1:静态代理出现的实际背景,静态代理时如何演化成动态代理 2: 动态代理demo 举例实际应用场景(载入数据库驱动的时候,使用AIDL与系统Servic...4: 动态代理使用到基础理论:Class.forName("xxxx") 得到Class类 。

    java 实现数据库增删查改

    这里通过调用`Class.forName()`加载特定的数据库驱动,然后使用`DriverManager.getConnection()`方法建立与数据库的连接。参数包括数据库的URL、用户名和密码。 #### 3. 插入数据(Insert) 使用`Statement`或`...

    Java连接sql_server2008数据库.pdf

    - `Class.forName`用于加载JDBC驱动。 - `DriverManager.getConnection`用于获取数据库连接。 - `createStatement`创建了一个`Statement`对象,用于执行SQL语句。 4. **关闭数据库连接**: ```java private ...

    Java连接sql_server2008数据库

    - `Class.forName`用于加载JDBC驱动。 - `getConnection`方法建立到数据库的实际连接。 - 连接字符串`jdbc:sqlserver://localhost:1433;databaseName=JLSS`指定了数据库服务器的位置和要连接的数据库名称。 - 用户名...

    java+web题库.pdf

    12. 加载数据库驱动的方法是 Class.forName(),连接数据源的方法是 connection con=DriverManager.getConnection(jdbc:odbc:数据源名)。 六、 选择题解析 1. 下面哪一个不是 JSP 本身已加载的基本类?答案:B java...

    oracle 存储过程 databaselink 收集

    Class.forName(driver); conn = DriverManager.getConnection(strUrl, "hyq", "hyq"); cstmt = conn.prepareCall("{call HYQ.TESTA(?, ?)}"); cstmt.setString(1, "100"); cstmt.setString(2, "TestOne"); ...

    oracle 存储过程 函数 dblink

    Class.forName(driver); Connection conn = DriverManager.getConnection(strUrl, "hyq", "hyq"); CallableStatement proc = conn.prepareCall("{call HYQ.TESTA(?,?)}"); proc.setString(1, "100"); proc....

    JDBC SQl Server 2000 Drvier

    1. **加载驱动**:通过`Class.forName()`方法加载JDBC驱动类。 2. **建立连接**:使用`DriverManager.getConnection()`方法,提供数据库URL、用户名和密码。 3. **创建Statement或PreparedStatement对象**:用于执行...

    JDBC访问MySQL数据库.docx

    - 在Java代码中,通过`Class.forName()`方法加载MySQL的JDBC驱动类,例如`com.mysql.cj.jdbc.Driver`。这会确保JVM能够识别并使用该驱动来建立与MySQL服务器的连接。 3. **建立数据库连接**: - 使用`...

    java web测试数据库连接是否正常

    2. **加载JDBC驱动**:在Java程序中,我们需要加载对应的JDBC驱动,这通常是通过`Class.forName()`方法完成的。对于Oracle,驱动类名为`oracle.jdbc.OracleDriver`。 3. **建立连接**:使用`DriverManager.get...

    mysql_jdbc连接数据库-错误提示.pdf

    Class.forName("com.mysql.cj.jdbc.Driver"); ``` **解决方法**: 1. **将驱动包放置于正确位置**:将MySQL驱动包(如mysql-connector-java-5.0.8-bin.jar)放置于JDK的`jre\lib\ext\`目录下。 2. **配置开发环境**...

    JDBC中操作Blob、Clob等对象

    Class.forName("org.apache.derby.jdbc.EmbeddedDriver").newInstance(); Connection conn = DriverManager.getConnection(url); Statement s = conn.createStatement(); s.executeUpdate("CREATE TABLE ...

    考研英语口语的自我介绍精选.doc

    xxxx middle School and served as a head-teacher of a class in junior grade two.” 4. **个人品质和兴趣**:分享你的性格特点和兴趣爱好,这有助于展现你的多元面貌。例如:“I am open-minded, quick in ...

    考研英语面试__自我介绍以及问题答案.pdf,这是一份不错的文件

    My hometown is renowned for its XXXX and XXXX (名胜或特产). Each year, numerous visitors, including foreigners from Europe, flock there to appreciate the scenic beauty.” 描述家乡的历史和文化特色,能...

    微信小程序中页面FOR循环和嵌套循环

    微信小程序中页面FOR循环和嵌套循环 单个循环 <view wx:for={{pinpaiTishi}} ... wx:key={{xxxx}}> //判断name是否为null <view class=tr> <view class=td-left> <view class=td-right> <view bindtap=oncli

    HttpDns Android客户端接入文档(腾讯内部业务专用)1

    将`HttpDNSLibs/HttpDNS_xxxx.jar`添加到项目的`libs`目录,并将`HttpDNSLibs/*/libhttpdns.so`放到`jniLibs`目录,以包含必要的本地库。同时,如果涉及到Beacon功能,还需添加`HttpDNSLibs/beacon-android-xxxx....

    php中用phpmailer发送邮件.pdf

    $mail->Username = "user@xxxx.com"; // 邮局用户名 $mail->Password = "******"; // 邮局密码 ``` 4. **设置发件人信息**:定义邮件的发送者邮箱和名称。 ```php $mail->From = "user@xxxx.com"; $mail->...

    Struts常见错误及原因分析

    3. 异常 No action instance for path /xxxx could be created 这个错误意味着无法创建Action实例。首先,确保Action类已正确编译并位于正确的类路径下,如WEB-INF/classes目录。其次,确认Action类继承自org....

Global site tag (gtag.js) - Google Analytics