java设计模式(2) 建造者模式,深复制与浅复制


《一》建造者模式


建造者模式 就是建造不同的东西,但是基本流程不变,将复杂的对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。
//构建产品
public class Person {
private String head;
private String body;
private String foot;
public String getHead() {
return head;
}
public void setHead(String head) {
this.head = head;
}
public String getBody() {
return body;
}
public void setBody(String body) {
this.body = body;
}
public String getFoot() {
return foot;
}
public void setFoot(String foot) {
this.foot = foot;
}

}

//产品接口
public interface PersonBuilder {
void buildhead();
void buildbody();
void buildfoot();
Person buildperson();
}

//实例一个产品
public class ManBuilder implements PersonBuilder{

Person person;


public  ManBuilder(){
    person = new Person();
}
public void buildhead() {

    person.setHead("建造男人的头");
}

public void buildbody() {

    person.setBody("建造男人的身体");
}

public void buildfoot() {

    person.setFoot("建造男人的脚");
}

public Person buildperson() {

    return person;
}

}

//调用具体建造者来创建对象的各个部分,不涉及具体信息,
//之负责保证对象各部分完整创建。
public class PersonDirector {
public Person constructPerson(PersonBuilder pb){
pb.buildbody();
pb.buildfoot();
pb.buildhead();
return pb.buildperson();
}
}

public class Test {

public static void main(String[] args) {
    // TODO Auto-generated method stub
      PersonDirector pd=new PersonDirector();
      Person person=pd.constructPerson(new ManBuilder());
      System.out.println(person.getHead());
      System.out.println(person.getBody());
      System.out.println(person.getFoot());
}

}

UML


《二》 深复制与浅复制


1.浅复制
被复制对象的所有变量都含有与原来的对象相同的值,而所有的对其他对象的引用仍然指向原来的对象,浅复制仅仅复制所考虑的对象,而不复制它所引用的对象。

//浅拷贝
public class Person implements Cloneable{
private int age;
private String name;
public Person(int age,String name){
this.age=age;
this.name=name;
}
public Person(){}
public int getAge(){
return age;
}
public String getName(){
return name;
}
public static void main(String[] args){
Person p=new Person(23,”ha “);
Person p1=null;
try {
p1 = (Person)p.clone(); //克隆
} catch (CloneNotSupportedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//测试p和p1是否指向同一对象
String result=p.getName()== p1.getName()?”clone是浅拷贝”:”clone是深拷贝”;
System.out.println(result);
}

}

2、深复制
被复制对象的所有变量都含有与原来的对象相同的值,但不指向原来的对象。
class Professor implements Cloneable
{
String name;
int age;
Professor(String name,int age)
{
this.name=name;
this.age=age;
}
public Object clone()
{
Object o=null;
try
{
o=super.clone(); //对o也进行克隆
}
catch(CloneNotSupportedException e)
{
System.out.println(e.toString());
}
return o;
}
}

class Student implements Cloneable {
String name;
int age;
Professor p;
Student(String name,int age,Professor p)
{
this.name=name;
this.age=age;
this.p=p;
}
public Object clone()
{
Student o=null;
try
{
o=(Student)super.clone();

  } 
 catch(CloneNotSupportedException e) 
 { 
    System.out.println(e.toString()); 
  } 
  o.p= (Professor)p.clone();//关键句
  return o; 

}
}
public class DeepCopy{
public static void main(String[] args)
{
Professor p=new Professor(“wangwu”,50);
Student s1=new Student(“zhangsan”,18,p);
Student s2=(Student)s1.clone();
s2.p.name=”lisi”;
s2.p.age=30;
System.out.println(“name=”+s1.p.name+”,”+”age=”+s1.p.age);
System.out.println(“name=”+s2.p.name+”,”+”age=”+s2.p.age);
}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
建造者模式是一种创建型设计模式,它允许你创建复杂对象的不同表示,并且可以在不暴露对象创建细节的情况下,将其构造过程分离出来。下面是一个 Java 建造者模式的例子: ``` public class Person { private String name; private int age; private String address; private String phone; public static class Builder { private String name; private int age; private String address; private String phone; public Builder(String name, int age) { this.name = name; this.age = age; } public Builder setAddress(String address) { this.address = address; return this; } public Builder setPhone(String phone) { this.phone = phone; return this; } public Person build() { return new Person(this); } } private Person(Builder builder) { this.name = builder.name; this.age = builder.age; this.address = builder.address; this.phone = builder.phone; } // getters and setters } ``` 在这个例子中,我们创建了一个名为 Person 的,它有四个属性:name、age、address 和 phone。我们使用了一个名为 Builder 的静态内部来构建 Person 对象。Builder 中有一个构造函数,它接受 name 和 age 两个参数,并且有三个可选的方法:setAddress、setPhone 和 build。setAddress 和 setPhone 方法用于设置 address 和 phone 属性,它们都返回 Builder 对象本身,以支持链式调用。build 方法用于创建 Person 对象,并且将 Builder 对象中的属性复制到 Person 对象中。最后,我们在 Person 中定义了一个私有构造函数,它接受一个 Builder 对象,并且将 Builder 对象中的属性复制到 Person 对象中。 使用建造者模式,我们可以像下面这样创建 Person 对象: ``` Person person = new Person.Builder("张三", 20) .setAddress("北京市朝阳区") .setPhone("13888888888") .build(); ``` 这样,我们就可以创建一个具有多个属性的 Person 对象,而不需要在构造函数中传递大量的参数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值