讲解Java设计模式编程中的建造者模式与原型模式
建造者模式 当创建复杂对象的算法应该独立于该对象的组成部分时,而且构造过程必须允许被构造的对象有不同的表示时。我们可以考虑使用建造者模式。 实现
1. Builder为创建一个Product对象的各个部件指定抽象接口。通常包含创建产品和返回产品的抽象方法,也可以是具体方法,把创建过程放到ConcreteBuilder类中。 /** "Product" */ class Pizza { private String dough = ""; private String sauce = ""; private String topping = ""; public void setDough (String dough) { this.dough = dough; } public void setSauce (String sauce) { this.sauce = sauce; } public void setTopping (String topping) { this.topping = topping; } } ''/** "Abstract Builder" */'' abstract class PizzaBuilder { protected Pizza pizza; public Pizza getPizza() { return pizza; } public void createNewPizzaProduct() { pizza = new Pizza(); } public abstract void buildDough(); public abstract void buildSauce(); public abstract void buildTopping(); } /** "ConcreteBuilder" */ class HawaiianPizzaBuilder extends PizzaBuilder { public void buildDough() { pizza.setDough("cross"); } public void buildSauce() { pizza.setSauce("mild"); } public void buildTopping() { pizza.setTopping("ham+pineapple"); } } /** "ConcreteBuilder" */ class SpicyPizzaBuilder extends PizzaBuilder { public void buildDough() { pizza.setDough("pan baked"); } public void buildSauce() { pizza.setSauce("hot"); } public void buildTopping() { pizza.setTopping("pepperoni+salami"); } } ''/** "Director" */'' class Waiter { private PizzaBuilder pizzaBuilder; public void setPizzaBuilder (PizzaBuilder pb) { pizzaBuilder = pb; } public Pizza getPizza() { return pizzaBuilder.getPizza(); } public void constructPizza() { pizzaBuilder.createNewPizzaProduct(); pizzaBuilder.buildDough(); pizzaBuilder.buildSauce(); pizzaBuilder.buildTopping(); } } /** A customer ordering a pizza. */ class BuilderExample { public static void main(String[] args) { Waiter waiter = new Waiter(); PizzaBuilder hawaiian_pizzabuilder = new HawaiianPizzaBuilder(); PizzaBuilder spicy_pizzabuilder = new SpicyPizzaBuilder(); waiter.setPizzaBuilder ( hawaiian_pizzabuilder ); waiter.constructPizza(); Pizza pizza = waiter.getPizza(); } } 客户创建Director对象,并用它所想要的Builder对象进行配置。Director取得客户的请求创建产品,最后取得产品。 优点 相关模式
实现 1. Client - 创建一个新的对象,然后通过clone得到另外一个对象。 public interface Prototype { public abstract Object clone ( ); } public class ConcretePrototype implements Prototype { public Object clone() { return super.clone(); } } public class Client { public static void main( String arg[] ) { ConcretePrototype obj1= new ConcretePrototype (); ConcretePrototype obj2 = ConcretePrototype)obj1.clone(); } } 实例 相关问题和实现 java中只要实现Cloneable接口就可以调用Object类的clone方法实现浅复制: public class ShallowClone implements Cloneable { int age; Person person; public void setAge(int age){ this.age = age; } public void setPerson(String name){ person = new Person(name); } public Object clone() throws CloneNotSupportedException{ // 默认java实现的是浅复制 return super.clone(); } } public class Person { String name; public Person(String name){ this.name = name; } } public class Test { public static void main(String[] args) throws CloneNotSupportedException { ShallowClone oldShallowClone = new ShallowClone(); oldShallowClone.setAge(20); oldShallowClone.setPerson("eric"); System.out.println("oldname: " + oldShallowClone.person.name + " age: " + oldShallowClone.age); ShallowClone newShallowClone = (ShallowClone)oldShallowClone.clone(); System.out.println("newname: " + newShallowClone.person.name + " age: " + newShallowClone.age); oldShallowClone.age = 30; oldShallowClone.person.name = "frank"; System.out.println("newname: " + newShallowClone.person.name + " age: " + newShallowClone.age); } } 输出: oldname: eric age: 20 newname: eric age: 20 newname: frank age: 20 可见浅复制复制的是对象的引用,当改变对象的值时,复制后的对象也会改变,而java的基本类型是复制的值。 下面我们实现深复制: public class DeepClone { int age; Person person; public void setAge(int age){ this.age = age; } public void setPerson(String name){ person = new Person(name); } public DeepClone(DeepClone deepClone){ this.age = deepClone.age; this.person = new Person(deepClone.person.name); } public DeepClone() {} public Object clone() throws CloneNotSupportedException{ return new DeepClone(this); } } public class Test { public static void main(String[] args) throws CloneNotSupportedException { DeepClone oldDeepClone = new DeepClone(); oldDeepClone.setAge(20); oldDeepClone.setPerson("eric"); System.out.println("oldname: " + oldDeepClone.person.name + " age: " + oldDeepClone.age); DeepClone newDeepClone = (DeepClone)oldDeepClone.clone(); System.out.println("newname: " + newDeepClone.person.name + " age: " + newDeepClone.age); oldDeepClone.age = 30; oldDeepClone.person.name = "frank"; System.out.println("newname: " + newDeepClone.person.name + " age: " + newDeepClone.age); } } 输出: oldname: eric age: 20 newname: eric age: 20 newname: eric age: 20 上面的复制方法中,我们重新创建了一个对象,并且重新创建了引用,实现了深度复制。 优点
您可能感兴趣的文章:
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |