您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關java中懶漢和餓漢模式有什么不同,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
1. 簡單,只需理解基本的概念,就可以編寫適合于各種情況的應用程序;2. 面向對象;3. 分布性,Java是面向網絡的語言;4. 魯棒性,java提供自動垃圾收集來進行內存管理,防止程序員在管理內存時容易產生的錯誤。;5. 安全性,用于網絡、分布環境下的Java必須防止病毒的入侵。6. 體系結構中立,只要安裝了Java運行時系統,就可在任意處理器上運行。7. 可移植性,Java可以方便地移植到網絡上的不同機器。8.解釋執行,Java解釋器直接對Java字節碼進行解釋執行。
1、區別
懶漢比較懶,只有當調用getInstance的時候,才回去初始化這個單例。
餓漢就是類一旦加載,就把單例初始化完成,保證getInstance的時候,單例是已經存在的了
線程安全:
餓漢式天生線程安全,可直接用于多線程,無任何問題,
懶漢風格本身是非線程安全的(雙檢鎖解決并發問題)
資源加載和性能:
餓漢式在類創建的同時實例化一個靜態對象出來,無論以后是否使用該單例,都會占用一定的內存,但相應地,由于其資源已初始化,第一次調用的速度也會更快。
懶漢式,會延遲加載,在第一次使用本單例時才會出現實例對象,第一次調用時要做初始化,如果要做的工作比較多,性能會有些延遲,以后就像餓漢式一樣。
2、實例
public class SingleTon01 { public static void main(String[] args) { GirlFriend gf1 = GirlFriend.getGf(); GirlFriend gf2 = GirlFriend.getGf(); //true System.out.println(gf1 == gf2); Cat cat1 = Cat.getCat(); Cat cat2 = Cat.getCat(); //true System.out.println(cat1 == cat2); } } /** * 單例模式-餓漢模式 * 在類加載的時候就會創建對象 */ class GirlFriend { public String name; private static GirlFriend gf = new GirlFriend("小紅"); public static GirlFriend getGf() { return gf; } /** * 構造器私有化,不能在本類之外new * @param name */ private GirlFriend(String name) { this.name = name; } @Override public String toString() { return "GirlFriend{" + "name='" + name + '\'' + '}'; } } /** * 單例模式-懶漢模式 * 1.構造器私有化 * 2.提供一個static靜態屬性對象 * 3.提供一個public的static方法,返回一個實例對象 * 4.懶漢模式,只有在用戶調用方法時,才會創建對象,之后再次調用,返回的是同一對象 */ class Cat { private String name; private static Cat cat; private Cat(String name) { this.name = name; } public static Cat getCat() { if (cat == null) { cat = new Cat("加菲貓"); } return cat; } @Override public String toString() { return "Cat{" + "name='" + name + '\'' + '}'; } }
上述就是小編為大家分享的java中懶漢和餓漢模式有什么不同了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。