Builder 构建器模式(建造者模式) :指将一个复杂对象的构造与它的表示分离,使同样的构建过程可以创建不同的表示,这样的设计模式被称为建造者模式。它是将一个复杂的对象分解为多个简单的对象,然后一步一步构建而成。它将变与不变相分离,即产品的组成部分是不变的,但每一部分是可以灵活选择的。
实例:
public class Builder {
//我们在使用的使用,用到哪些属性,设置哪些属性就行,不用每个都设置,空的传null。
Person p = new Person.PersonBuilder()
//假如基础信息必须传,这里可以写上
.basicInfo(1, "张三", 18)
//如果体重不重要,这里可以直接注释掉,不用设置
//.weight(60)
.score(100)
.loc("家住在北京海淀区")
.builder();
}
class Person{
private int id;
private String name;
private int age;
private double weight;
private int score;
private String loc;
//....参数特别多
private Person(){} //这里不让直接创建,需要用下面的构建起实例化
public static class PersonBuilder{
Person p = new Person();
//基础信息
public PersonBuilder basicInfo(int id, String name, int age){
p.id = id;
p.name = name;
p.age = age;
return this;
}
public PersonBuilder weight(double weight){
p.weight = weight;
return this;
}
public PersonBuilder score(int score){
p.score = score;
return this;
}
public PersonBuilder loc(String loc){
p.loc = loc;
return this;
}
public Person builder(){
return p;
}
}
}
通过上面的实例,如果用过swagger的人,应该会比较有感触, 配置swagger的代码跟上面person使用一模一样。
网上找的实例:
@Configuration//托管spring
@EnableSwagger2//开启swagger功能
public class SwaggerConfig {
//代码补全,省略。。。。
/**
* 创建该API的基本信息(这些基本信息会展现在文档页面中)
* 访问地址:http://项目实际地址/swagger-ui.html
* @return
*/
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("使用Swagger2 构建RESTful APIS - zy") //接口管理文档首页显示
.description("zy - Swagger使用演示")//API的描述
.termsOfServiceUrl("www.footmark.top")//网站url等
.version("1.0")
.build();
}
}