作者:gnuhpc
出处:http://www.cnblogs.com/gnuhpc/
1.概述
这个模式在Head First这本书中也没有具体提到。其主要应用于如下场景:对于创建一个新的对象,若且你手中已经有了一个非常相像的对象实例,那么你可以利用这个现有对象进行新对象的创建。用现实中的例子来说,比如细胞分裂,一个细胞分裂为两个细胞(可能这个比喻在生物学上有些出入)。参与这个模式的两种实体为:
原型:一个提供克隆自己的接口的抽象。
具体原型:实现这个克隆自己的的接口的具体实现类。
2.实例
首先我们实现一个原型模式的原始例子,这里利用了Java中Object的clone()方法:
显然上边的这个例子并没有多少实用性,下边的例子中我们要创建一个具有克隆自己功能的表示相关产品的对象,实现上利用了简单工厂方法——这个经常和原型模式一起使用。
我们利用Java中的Cloneable接口定义原型,其中就提供了一个克隆自己的方法的接口定义。然后我们实现这个具体原型,当然相对于标准的原型模式,这里面有增加了一层产品的抽象,因为毕竟Java中的Cloneable是一个接口,需要有一层实现这个接口中clone方法的抽象作为抽象产品类。
然后我们根据这个抽象类创建两个具体的原型类,如果用简单工厂方法的视角那就是一个具体产品类,不过这并不要紧:
现在我们创建一个工厂(为了演示多个具体产品类,这个工厂定义的比较特殊——生产书和衣服)来创建这些产品:
这个工厂的特殊之处是需要复制的对象已经创立好了,在创建工厂实例的时候通过loadCache就可以完成。
下边我们使用这个工厂克隆生产一本书和一件衣服:
3.UML总结这里没有画简单工厂模式的实体。
原型模式多用于创建复杂的或者耗时的实例,因为这种情况下,复制一个已经存在的实例使程序运行更高效;或者创建值相等,只是命名不一样的同类数据(克隆以后进行定制)。
作者:gnuhpc
出处:http://www.cnblogs.com/gnuhpc/
作者:gnuhpc
出处:http://www.cnblogs.com/gnuhpc/
除非另有声明,本网站采用知识共享“署名 2.5 中国大陆”许可协议授权。