ClassForName应用于工厂模式
一、應用工廠
接口:
package com.example.demo.service;public interface IFruitFactory {public void sell(int count) ;public void eat();}實現類:
package com.example.demo.service.impl;import com.example.demo.service.IFruitFactory;public class Apple implements IFruitFactory {@Overridepublic void sell(int count) {System.out.println("蘋果售價:"+count);}@Overridepublic void eat() {// TODO Auto-generated method stub}} package com.example.demo.service.impl;import com.example.demo.service.IFruitFactory;public class Orange implements IFruitFactory{@Overridepublic void sell(int count) {System.out.println("橘子售價:"+count);}@Overridepublic void eat() {// TODO Auto-generated method stub}}測試類:
package com.example.demo.service.impl;import com.example.demo.service.IFruitFactory;public class TestClassForName {public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException {String appleStr = "com.example.demo.service.impl.Apple";Class<?> c = Class.forName(appleStr);IFruitFactory fruit = (IFruitFactory)c.newInstance();fruit.sell(3);String orangeStr = "com.example.demo.service.impl.Orange";Class<?> c2 = Class.forName(orangeStr);IFruitFactory fruit2 = (IFruitFactory)c2.newInstance();fruit2.sell(4);}}測試結果:
蘋果售價:3
橘子售價:4
二.new 和Class.forName()有什么區別?
其實上面已經說到一些了,這里來做個總結:
首先,newInstance( )是一個方法,而new是一個關鍵字;
其次,Class下的newInstance()的使用有局限,因為它生成對象只能調用無參的構造函數,而使用 new關鍵字生成對象沒有這個限制。
簡言之:
newInstance(): 弱類型,低效率,只能調用無參構造。
new: 強類型,相對高效,能調用任何public構造。
Class.forName(“”)返回的是類。
Class.forName(“”).newInstance()返回的是object 。
三.為什么在加載數據庫驅動包的時候有用的是Class.forName( ),卻沒有調用newInstance( )?
在Java開發特別是數據庫開發中,經常會用到Class.forName( )這個方法。
通過查詢Java Documentation我們會發現使用Class.forName( )靜態方法的目的是為了動態加載類。
通常編碼過程中,在加載完成后,一般還要調用Class下的newInstance( )靜態方法來實例化對象以便操作。因此,單單使用Class.forName( )是動態加載類是沒有用的,其最終目的是為了實例化對象。
有數據庫開發經驗朋友會發現,為什么在我們加載數據庫驅動包的時候有的卻沒有調用newInstance( )方法呢?
有的jdbc連接數據庫的寫法里是Class.forName(xxx.xx.xx);而有一些:Class.forName(xxx.xx.xx).newInstance(),為什么會有這兩種寫法呢?
剛才提到,Class.forName(“”);的作用是要求JVM查找并加載指定的類,首先要明白,java里面任何class都要裝載在虛擬機上才能運行,而靜態代碼是和class綁定的,class裝載成功就表示執行了你的靜態代碼了,而且以后不會再走這段靜態代碼了。
而我們前面也說了,Class.forName(xxx.xx.xx)的作用就是要求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(xxx.xx.xx)返回的是一個類 Class.forName(xxx.xx.xx)的作用是要求JVM查找并加載指定的類, 也就是說JVM會執行該類的靜態代碼段這句話即解釋了jdbc驅動的加載本質。總結
以上是生活随笔為你收集整理的ClassForName应用于工厂模式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 安装ubuntu20.04,从格式化磁盘
- 下一篇: 计算机维修工程师认证,计算机维修工程师认