讀古今文學網 > 編寫高質量代碼:改善Java程序的151個建議 > 建議42:讓工具類不可實例化 >

建議42:讓工具類不可實例化

Java項目中使用的工具類非常多,比如JDK自己的工具類java.lang.Math、java.util.Collections等都是我們經常用到的。工具類的方法和屬性都是靜態的,不需要生成實例即可訪問,而且JDK也做了很好的處理,由於不希望被初始化,於是就設置構造函數為private訪問權限,表示除了類本身外,誰都不能產生一個實例,我們來看一下java.lang.Math代碼:


public final class Math{

/**

*Don't let anyone instantiate this class.

*/

private Math(){}

}


之所以要將"Don't let anyone instantiate this class."留下來,是因為Math的構造函數設置為private了:我就是一個工具類,我只想要其他類通過類名來訪問,我不想你通過實例對像訪問。這在平台型或框架型項目中已經足夠了。但是如果已經告訴你不能這麼做了,你還要生成一個Math實例來訪問靜態方法和屬性(Java的反射是如此的發達,修改個構造函數的訪問權限易如反掌),那我就不保證正確性了,隱藏問題隨時都有可能爆發!那我們在項目開發中有沒有更好的限制辦法呢?有,即不僅僅設置成private訪問權限,還拋異常,代碼如下:


public class UtilsClass{

private UtilsClass(){

throw new Error("不要實例化我!");

}

}


如此做才能保證一個工具類不會實例化,並且保證所有的訪問都是通過類名來進行的。需要注意一點的是,此工具類最好不要做繼承的打算,因為如果子類可以實例化的話,那就要調用父類的構造函數,可是父類沒有可以被訪問的構造函數,於是問題就會出現。

注意 如果一個類不允許實例化,就要保證「平常」渠道都不能實例化它。