空对象模式(Null Object Pattern)

本文节选自《设计模式就该这样学》

1 空对象模式的定义

空对象模式(Null Object Pattern)不属于GoF设计模式,但是它作为一种经常出现的模式足以被视为设计模式了。其具体定义为设计一个空对象取代NULL对象实例的检查。NULL对象不是检查控制,而是反映一个不做任何动作的关系。这样的NULL对象也可以在数据不可用的时候提供默认的行为,属于行为型设计模式。

原文:Provide an object as a surrogate for the lack of an object of a given type. The Null object provides intelligent do nothing behavior, hiding the details from its collaborators.

2 空对象模式的应用场景

空对象模式适用于以下应用场景。

(1)对象实例需要一个协作实例。空对象模式不会引入协作实例,它只是使用现有的协作实例。

(2)部分协作实例不需要做任何处理。

(3)从客户端中将对象实例不存在的代码逻辑抽象出来。

3 空对象模式的UML类图

空对象模式的UML类图如下图所示。

空对象模式(Null Object Pattern)_第1张图片

由上图可以看到,空对象模式主要包含3个角色。

(1)抽象对象(AbstractObject):定义所有子类公有的行为和属性。

(2)真实对象(RealObject):继承AbstractObject类,并实现所有行为。

(3)空对象(NullObject):继承AbstractObject类,对父类方法和属性不做实现和赋值。

4 空对象模式的通用写法

以下是空对象模式的通用写法。


public class Client {

    public static void main(String[] args) {
        ObjectFactory factory = new ObjectFactory();
        System.out.println(factory.getObject("Joe").isNill());
        System.out.println(factory.getObject("Tom").isNill());
    }


    //抽象对象
    static abstract class AbstractObject{
        abstract void request();
        abstract boolean isNill();
    }

    //空对象
    static class NullObject extends AbstractObject{

        public void request() {
            System.out.println("Not Available Request");
        }

        boolean isNill() {
            return true;
        }
    }

    //真实对象
    static class RealObject extends AbstractObject{
        private String name;
        public RealObject(String name) {
            this.name = name;
        }

        public void request() {
            System.out.println("Do samething...");
        }

        boolean isNill() {
            return false;
        }
    }

    //对象工厂
    static class ObjectFactory{
        private static final String[] names = {"Tom","Mic","James"};

        public AbstractObject getObject(String name){
            for (String n : names) {
                if(n.equalsIgnoreCase(name)){
                    return new RealObject(name);
                }
            }
            return new NullObject();
        }
    }
}

5 空对象模式的优点

(1)它可以加强系统的稳固性,能有效地减少空指针报错对整个系统的影响,使系统更加稳定。

(2)它能够实现对空对象情况的定制化的控制,掌握处理空对象的主动权。

(3)它并不依靠Client来保证整个系统的稳定运行。

(4)它通过定义isNull()对使用条件语句==null的替换,显得更加优雅,更加易懂。

6 空对象模式的缺点

每一个要返回的真实的实体都要建立一个对应的空对象模型,那样会增加类的数量。

关注微信公众号『 Tom弹架构 』回复“设计模式”可获取完整源码。

【推荐】Tom弹架构:30个设计模式真实案例(附源码),挑战年薪60W不是梦

本文为“Tom弹架构”原创,转载请注明出处。技术在于分享,我分享我快乐!
如果本文对您有帮助,欢迎关注和点赞;如果您有任何建议也可留言评论或私信,您的支持是我坚持创作的动力。关注微信公众号『 Tom弹架构 』可获取更多技术干货!

你可能感兴趣的