被遗忘的设计模式——空对象模式(Null Object Pattern)
2016-10-09 14:27
411 查看
一、Pattern name
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.
二、Problem
任何没有实际应用场景的设计模式,都是在耍流氓。学习设计模式,不仅仅是为了领悟其精髓,更为了在实践设计当中去运用,去变通,下面我们来看看,什么情况下,这个Null Object Pattern会派上用场呢?假设这样一个场景:
在一个图书信息查询系统中,你调用一个方法,传过去你要查找图书的ID,然后它返回给你,你要查找的图书对象,这样你就可以调用对象的方法来输出图书的信息。
我想这种场景在程序设计中还是比较常见的。下面,我们来实现以下具体的代码。
首先,我们来看一下ConcreteBook类的代码(提供构造函数和展示图书信息的show()方法。):
?
?
?
很好,运行很顺利,这时,我们把ConcreteBook book = bookFactory.getBook(1);中的1改为2,恩,也运行成功。这时候,我们改成-1。再来运行一下,发现如下报错:<喎�"/kf/ware/vc/" target="_blank" class="keylink">vcD4NCjxwPjxpbWcgYWx0PQ=="这里写图片描述" src="/uploadfile/Collfiles/20150408/20150408084642355.png" title="\" />
空指针报错,是的,这应该是Java初学者见到最多的报错了。它提示我们第28行book.show()报错。这是为什么呢?因为我们通过bookFactory.getBook()方法获取ConcreteBook对象的时候,如果我们传入的参数,即图书的ID,属于非法值(如-1)或者不存在(如3)的话(其实这种情况是经常遇到的。),就会返回null,表示我们查找的图书信息并不存在。这时,book为null.你再调用book.show()。当然要报空指针的错误了。那怎么解决呢?
我们比较常规的做法就是在客户端加一个判断,判断是否为null。如果为null的话,就不再调用show()方法。如果不为null再调用show()方法。更改如下:
?
但是,你有没有考虑过?这样做,确实消除了报错,但是这样做真的好吗?你想如果在一段程序中有很多处调用getBook()方法或者有很多个客户端的话(比如图书馆的查询终端肯定不止一个啊),岂不是很多处都要判断book对象是否为null?这还不算坏,如果哪一处没有判断,然后报错了,很有可能导致程序没法继续运行甚至崩溃。而且,你要记住,永远都不要太相信客户端(Client),不要把整个程序的稳定性寄托在客户端身上。还有,像上面的处理方法,当获取对象为null的时候,输出的提示信息是有客户端来定制的,这样岂不是把主动权交给了客户端,而不是我们系统本身?
那究竟应该如何实现才会更加合适呢?那就要用到我们今天要将的Null Object Pattern——一种被遗忘的设计模式
三、Solution
首先,我们来看一下Null Object Pattern的UML类图结构:这个类图结构其实还是很简单的,这里面的RealObject其实就相当于我们的ConcreteBook类,而NullObject就是我们将要增加的空对象类,而AbstractObject类就是我们要提出来的父类。我们只是在Client和AbstractObject之间增加了一个BookFactory而已。
下面,我们来改一下我们的代码:
新增的抽象接口Book类的代码:
?
?
?
?
?
比如我们进行如下修改,修改后的NullBook类代码:
?
其实,虽然在客户端我们不进行检测也可以保证程序不报错,但是最好的方式,还是进行相应的检测,如下:
?
四、Consequences
Null Object Pattern,作为一种被遗忘的设计模式,却有着不能被遗忘的作用。(1)它可以加强系统的稳固性,能有有效地防止空指针报错对整个系统的影响,使系统更加稳定。
(2)它能够实现对空对象情况的定制化的控制,能够掌握处理空对象的主动权。
(3)它并不依靠Client来保证整个系统的稳定运行。
(4)它通过isNull对==null的替换,显得更加优雅,更加易懂。
五、总结
到这里,我们的Null Object Pattern就介绍完了,还可以参考这篇资料,也是讲得很不错的。http://www.cs.oberlin.edu/~jwalker/nullObjPattern/原文地址:http://www.2cto.com/kf/201504/388387.html
相关文章推荐
- 被遗忘的设计模式——空对象模式(Null Object Pattern)
- 被遗忘的设计模式——空对象模式(Null Object Pattern)
- Java 空对象设计模式(Null Object Pattern) 讲解
- 设计模式:空对象模式(Null Object Pattern)
- Java 空对象设计模式(Null Object Pattern) 讲解
- 设计模式:空对象模式(Null Object Pattern)
- 设计模式:空对象模式(Null Object Pattern)
- 【设计模式】空对象模式(Null Object Pattern)
- 设计模式拾荒之中介者模式(Mediator Pattern): 避免对象间错综复杂的相互引用
- 设计模式学习—空对象模式(Null Object Design Pattern)
- 设计模式之空对象(Null Object)模式
- 【设计模式 - 21】之空对象模式(Null Object)
- 设计模式之空对象(Null Object)模式
- 【设计模式】传输对象模式(Transfer Object Pattern)
- C#对象为Null模式(Null Object Pattern)实例教程
- 空对象模式(Null Object Pattern)
- 面向对象设计模式之---简易工厂模式(Simple Factory Pattern)
- 建造者模式-Builder Pattern 复杂对象的组装与创建——建造者模式(二):游戏角色设计的建造者模式解决方案
- 类对象工厂设计模式(Factory Pattern)
- 用最简单的例子理解对象为Null模式(Null Object Pattern)