在“空对象”模式中,空对象将替换NULL
对象实例的检查。而不是检查一个空值,Null
对象反映一个无关的关系(即什么也不做)。 这种Null
对象还可以用于在数据不可用时提供默认行为。
在空对象模式(Null Object模式)中创建一个抽象类,指定要执行的各种操作。扩展此类的具体类和一个null对象类,不提供此类的任何实现,并且无需检查空值。
实现实例
在这个实例中,将创建一个AbstractCustomer
抽象类来定义一些操作。这里的客户名称和扩展AbstractCustomer
类的具体类。 创建工厂类CustomerFactory
用来根据传递给它的客户名称返回RealCustomer
或NullCustomer
对象。
NullPatternDemo
这是一个演示类,将使用CustomerFactory
演示使用空对象模式(Null Object)模式。
空对象示例的结构如下图所示 -
第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