JAVA創(chuàng)建和銷毀對象的方法
創(chuàng)建對象的幾種方式
- 構(gòu)造器
- 靜態(tài)工廠方法
- 通過Builder
靜態(tài)工廠方法優(yōu)點
- 有名稱-調(diào)用更清晰
- 每次調(diào)用時不會創(chuàng)建一個新對象
- 可以返回原返回類型的任何子類型的對象
- 創(chuàng)建參數(shù)化類型實例的時候,使代碼更簡潔
靜態(tài)工廠方法缺點
- 類如果不含共有的或受保護的構(gòu)造器,就不能被子類化
- 與其他靜態(tài)方法實際上沒有任何區(qū)別
遇到多個構(gòu)造器參數(shù)時要考慮用構(gòu)建器
重疊構(gòu)造器模式
但是,在有很多參數(shù)時,客戶端代碼難以編寫且難以閱讀。
JavaBeans模式。
調(diào)用一個無參構(gòu)造器來創(chuàng)建對象,調(diào)用 setter 方法來設(shè)置參數(shù)。
缺點:構(gòu)造過程被分到了幾個調(diào)用,導(dǎo)致可能處于不一致狀態(tài)。
Builder模式
讓客戶端利用所有必要參數(shù)調(diào)用構(gòu)造器/靜態(tài)工廠,得到builder對象,再調(diào)用類似于setter方法,最后調(diào)用無參的build方法來生成不可變對象。
public class NutritionFacts { private final int servingSize; private final int servings; private final int calories; private final int fat; private final int sodium; private final int carbohydrate; public static class Builder { //Required parameters private final int servingSize; private final int servings; //Optional parameters - initialized to default values private int calories = 0; private int fat = 0; private int carbohydrate = 0; private int sodium = 0; public Builder(int servingSize, int servings) { this.servingSize = servingSize; this.servings = servings; } public Builder calories(int val){ calories = val; return this; } public Builder fat(int val){ fat = val; return this; } public Builder carbohydrate(int val){ carbohydrate = val; return this; } public Builder sodium(int val){ sodium = val; return this; } public NutritionFacts build(){ return new NutritionFacts(this); } } private NutritionFacts(Builder builder) { servings = builder.servings; servingSize = builder.servingSize; calories = builder.calories; fat = builder.fat; sodium = builder.sodium; carbohydrate = builder.carbohydrate; } } //Client NutritionFacts cocaCola = new NutritionFacts.Builder(240, 8). calories(100).sodium(35).carbohydrate(27).build();
builder可以檢驗約束條件,并且可有多個可變參數(shù)。
但是Builder模式更為冗長,只有在很多參數(shù)(>=4)時才使用。
用私有構(gòu)造器或枚舉類型強化Singleton屬性
單元素的枚舉類型已經(jīng)成為實現(xiàn)Singleton的最佳方法。
public enum Elvis { INSTANCE; public void leaveTheBuilding() {...} }
這種方式提供了序列化機制,并可防止多次實例化。
通過私有構(gòu)造器強化不可實例化的能力
為了不被實例化,可使用私有構(gòu)造器來實現(xiàn)。
//Noninstantiable utility class public class UtilityClass { private UtilityClass() { throw new AssertionError(); } ... // Remainder omitted }
這種方式使得一個類不能被子類化。
所有構(gòu)造器必須顯式或隱式調(diào)用超類構(gòu)造器,在這種情形下,子類就沒有可訪問的超類構(gòu)造器調(diào)用。
避免創(chuàng)建不必要的對象
重用不可變對象,重用已知不會被修改的可變對象。
對于同時提供了靜態(tài)工廠方法和構(gòu)造器的不可變類,通??梢允褂渺o態(tài)工廠方法,避免創(chuàng)建不必要的對象。構(gòu)造器每次被調(diào)用時都會創(chuàng)建一個新對象。
自動裝箱(autoboxing)– 創(chuàng)建多余對象的新方法。要優(yōu)先使用基本類型而不是裝箱基本類型。
消除過期的對象調(diào)用
只要類是自己管理內(nèi)存,就應(yīng)該警惕內(nèi)存泄漏問題。一旦元素被釋放掉,則該元素中包含的任何對象引用都應(yīng)該被清空。
常見的內(nèi)存泄漏還有: 緩存、監(jiān)聽器和其他回調(diào)。
確?;卣{(diào)立即被當(dāng)作垃圾回收的最佳方法是只保存它們的弱引用。
避免使用終結(jié)方法
終結(jié)方法的缺點在于不能保證會被及時地執(zhí)行。
不應(yīng)該依賴終結(jié)方法來更新重要的持久狀態(tài)。
顯式的終止方法通常與try-finally結(jié)構(gòu)結(jié)合使用,以確保及時終止。
終止方法的用途
- 當(dāng)對象所有者忘記調(diào)用顯式終止方法時,終結(jié)方法可充當(dāng)“安全網(wǎng)” – 終結(jié)方法發(fā)現(xiàn)資源還未被終止,應(yīng)在日志中記錄一條警告。
- 終止非關(guān)鍵的本地資源。
使用了終結(jié)方法就要記住調(diào)用 super.finalize 。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java的this關(guān)鍵字的使用與方法的重載相關(guān)知識
這篇文章主要介紹了Java的this關(guān)鍵字的使用與方法的重載相關(guān)知識,是Java入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-09-09在RabbitMQ中實現(xiàn)Work queues工作隊列模式
這篇文章主要介紹了如何在RabbitMQ中實現(xiàn)Work queues模式,代碼詳細,解釋清晰,可以幫助大家更好理解java,對這方面感興趣的朋友可以參考下2021-04-04Spring Boot連接超時導(dǎo)致502錯誤的實戰(zhàn)案例
這篇文章主要給大家介紹了關(guān)于Spring Boot連接超時導(dǎo)致502錯誤的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09Java 批量獲取地址間距離工具(支持中轉(zhuǎn)站)
本文主要介紹了Java批量獲取地址間距離,獲取兩個地址間距離,實現(xiàn)方式比較多,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-07-07