空物件模式
在空物件模式(Null Object Pattern)中,一個空物件取代 NULL 物件實例的檢查。 Null 物件不是檢查空值,而是反應一個不做任何動作的關係。這樣的 Null 物件也可以在資料不可用的時候提供預設的行為。
在空物件模式中,我們建立一個指定各種要執行的操作的抽象類別和擴展該類別的實體類,還創建一個未對該類別做任何實現的空物件類,該空物件類別將無縫地使用在需要檢查空值的地方。
實作
我們將建立一個定義操作(在這裡,是客戶的名稱)的AbstractCustomer 抽象類,和擴展了AbstractCustomer 類的實體類別。工廠類別 CustomerFactory 基於客戶傳遞的名字來傳回 RealCustomer 或 NullCustomer 物件。
NullPatternDemo,我們的示範類別使用 CustomerFactory 來示範空物件模式的用法。
步驟 1
建立一個抽象類別。
AbstractCustomer.java
public abstract class AbstractCustomer { protected String name; public abstract boolean isNil(); public abstract String getName(); }
步驟 2
建立擴充了上述類別的實體類別。
RealCustomer.java
public class RealCustomer extends AbstractCustomer { public RealCustomer(String name) { this.name = name; } @Override public String getName() { return name; } @Override public boolean isNil() { return false; } }
NullCustomer.java
public class NullCustomer extends AbstractCustomer { @Override public String getName() { return "Not Available in Customer Database"; } @Override public boolean isNil() { return true; } }
步驟3
#建立 CustomerFactory 類別。
CustomerFactory.java
public class CustomerFactory { public static final String[] names = {"Rob", "Joe", "Julie"}; public static AbstractCustomer getCustomer(String name){ for (int i = 0; i < names.length; i++) { if (names[i].equalsIgnoreCase(name)){ return new RealCustomer(name); } } return new NullCustomer(); } }
步驟4
使用CustomerFactory,基於客戶傳遞的名字,來取得 RealCustomer 或NullCustomer 物件。
NullPatternDemo.java
public class NullPatternDemo { public static void main(String[] args) { AbstractCustomer customer1 = CustomerFactory.getCustomer("Rob"); AbstractCustomer customer2 = CustomerFactory.getCustomer("Bob"); AbstractCustomer customer3 = CustomerFactory.getCustomer("Julie"); AbstractCustomer customer4 = CustomerFactory.getCustomer("Laura"); System.out.println("Customers"); System.out.println(customer1.getName()); System.out.println(customer2.getName()); System.out.println(customer3.getName()); System.out.println(customer4.getName()); } }
步驟 5
驗證輸出。
Customers Rob Not Available in Customer Database Julie Not Available in Customer Database