您好,登錄后才能下訂單哦!
Java單例模式的原理是什么,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
1,單例模式的要素
1)私有構造方法。
2)public static synchronized的getInstance()方法。
上述2個要素雖然可以保證單例模式的實現,但并不是最好的方式。因為當我們討論性能時,synchronized方法有著非常昂貴的代價。
2,多線程使用環境下的線程安全實現方式
a)使用double locking機制的懶初始化。代碼如下。在這種情況下,當調用getInstance方法時,才會創建單例對象。
b)使用靜態屬性的早初始化。代碼如下。下面的實現方式,當類被加載時,單例對象就會創建。因為單例對象是靜態的。類只會被加載一次,保證了單例對象的唯一性。
3,protected 的構造函數
有時候,為了能夠繼承單例類,我們可以使用protected的構造函數。但是,這樣會有2個缺點,讓單例繼承不實用。
第一點,如果構造函數是protected的,這意味著單例類可以被相同包下另一個類通過調用構造函數的方式來創建。一個可以避免這種情況的解決方法是,把單例類放在一個單獨的包里。
第二點,為了能夠使用繼承類,代碼中所有已經調用Singleton.getInstance方法的地方,都需要修改為DerivedSingleton.getInstance方法。
4,使用不同類加載器的情景
如果一個類被2個類加載器加載了,那么,在內存里,它們是2個不同的類。
5,序列化
如果一個單例類實現了Serializable接口,當單例序列化,然后多次反序列化時,將會有多個對象被創建。
熱點:
多線程:如果單例需要在多線程環境下使用,應該要特別留心。
序列化:當單例類實現了Serializable接口時,它必須重寫readResolve方法來避免出現2個對象。
類加載器:如果單例類被2個不同的類加載器加載,那么我們會有2個不同的類,一個類加載器會有一個類。
通過類目進行全局訪問:單例對象是通過類名獲取的。初看起來,這是一個訪問它的很簡單的方式,但卻不是很靈活。如果我們需要替換單例類,那么代碼中所有引用的地方都需要修改。
看完上述內容,你們掌握Java單例模式的原理是什么的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。