概念:
将复杂对象的构造与其表示分离,以便相同的构造过程可以创建不同的表示。也就是当一个对象比较复杂,而且每次的构造过程又相同的时候,可以考虑一下使用构建者模式。
public class Person {
private String name;
private String age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
//不提供默认的无参构造方法
//有参方法私有
private Person(String name, String age) {
super();
this.name = name;
this.age = age;
}
//提供构建者
public static Build build() {
return new Build();
}
public static class Build{
private String name;
private String age;
//设置参数
public Build setName(String name) {
this.name = name;
return this;
}
public Build setAge(String age) {
this.age = age;
return this;
}
//构建Person对象
public Person build() {
return new Person(name, age);
}
}
}
这里构建者模式是在需要构建的类外面,如果在类的内部也可以,不违法开闭原则,因为构建者类和需要构建的类的关系很紧密,并且构建者模式不与其他的类相互通信,放在需要构建的类里面,也可以。很多源码都是这样做的,并且这个时候 还不需要公开 set() get() 方法,这样进一步对类进行保护,你这个类能被别人调用的方法公开 不能被调用的方法不公开。更好的保护了对象,不至于由于别人调用的时候调用了set() get()方法修改成员变量导致逻辑出问题。
public class Person {
private String name;
private String age;
//提供构建者
public static Build build() {
return new Build();
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
public static class Build{
private Person person=new Person();
//设置参数
public Build setName(String name) {
person.name = name;
return this;
}
public Build setAge(String age) {
person.age = age;
return this;
}
//构建Person对象
public Person build() {
return person;
}
}
}