建造者模式
建造者模式是设计模式的一种,将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。 百度百科
高并发、设计模式、算法一直以来都是被拿出来反复鞭尸。但如果不去思考,不刻意使用,还是不能将设计模式引用到代码中。
当然,不用设计模式也完全可以实现,但对于复杂的系统,如果只是一味的增加修改,将来维护将是一场噩梦,周末想睡个安稳觉,不存在的。
学习一种模式首先想到的是使用场景,如果不知道学习它用来做什么,过几天也就抛之脑后了。
使用场景
百度百科说将一个复杂对象的构建与它的表示分离出来。抱歉,你说的太过官方,我不懂。那能不能通俗易懂呢?通俗将就是一个类如果要通过不同的字段来构造多个实例,就可以用建造者模式来处理。
实战
怎么办?我看了你的通俗易懂版还是没明白到底什么时候用,还能具体一点吗?不急,我们通过实例来说明,最近支付刚好有使用场景。
微信支付的统一下单,无论是H5、JSAPI还是Native以及其它模式,都用到了统一下单接口,除了固定的app_id、out_trade_no等是必填的,其它的都是不同场景需要的参数不一致,这时候就可以使用简化版的建造者模式,链式调用。
我们可以通过重载多个构造方法来实现,这种方式不仅阅读性差还没有逼格。这时候就该用链式调用提升逼格了。让接手你代码的兄弟不停称赞。
因统一下单字段较多,这里省略部分字段,示例。
package com.year.shiyi.aspect;
import lombok.Data;
/**
* @author shiyi on 2021/3/13 15:06
*/
@Data
public class UnifiedOrder {
private String appid;
private String mch_id;
private String sub_appid;
private String sub_mch_id;
private String device_info;
public UnifiedOrder(UnifiedOrder.UnifiedOrderModelBuilder builder) {
this.appid = builder.appid;
this.mch_id = builder.mch_id;
this.sub_appid = builder.sub_appid;
this.sub_mch_id = builder.sub_mch_id;
this.device_info = builder.device_info;
}
public static UnifiedOrder.UnifiedOrderModelBuilder builder() {
return new UnifiedOrderModelBuilder();
}
public static class UnifiedOrderModelBuilder {
private String appid;
private String mch_id;
private String sub_appid;
private String sub_mch_id;
private String device_info;
public UnifiedOrder.UnifiedOrderModelBuilder appid(String appid) {
this.appid = appid;
return this;
}
public UnifiedOrder.UnifiedOrderModelBuilder mch_id(String mch_id) {
this.mch_id = mch_id;
return this;
}
public UnifiedOrder.UnifiedOrderModelBuilder sub_appid(String sub_appid) {
this.sub_appid = sub_appid;
return this;
}
public UnifiedOrder.UnifiedOrderModelBuilder sub_mch_id(String sub_mch_id) {
this.sub_mch_id = sub_mch_id;
return this;
}
public UnifiedOrder.UnifiedOrderModelBuilder device_info(String device_info) {
this.device_info = device_info;
return this;
}
public UnifiedOrder builder () {
return new UnifiedOrder(this);
}
}
}
使用
public static void main(String[] args) {
UnifiedOrder unifiedOrder = UnifiedOrder.builder()
.appid("111")
.device_info("222")
.sub_appid("333")
.builder();
}
使用方便简单,链式调用传入需要的参数,构建不同对象。
还需要写静态内部类,感觉代码量增加了,写起来繁琐。
嗯?比起原先代码量可能增加了,但调用起来简单,可维护性高。
那还是代码量增加了呀,我只想早撸早下班。
呸,狗男人。还好我早有准备。
Lombok了解以下,使用注解简化大量代码
第一步:引入依赖,版本在mavenhub上自行查看
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
</dependency>
第二步:编辑器下载Lombok插件
第三步:改造代码
/**
* @author shiyi on 2021/3/13 15:06
*/
@Data
@Builder
public class UnifiedOrder {
private String appid;
private String mch_id;
private String sub_appid;
private String sub_mch_id;
private String device_info;
}
还和原来一样调用
public static void main(String[] args) {
UnifiedOrder unifiedOrder = UnifiedOrder.builder()
.appid("111")
.device_info("222")
.sub_appid("333")
.build();
System.out.println(unifiedOrder.toString());
}
闲代码量增加的同学知道怎么办了吧。
Lombok很强大,能让我们的代码更加整洁。还未使用的同学快去学习一波吧。
如果您有更优雅的实现,欢迎留言。
上次点赞、在看的人已经脱单!!!你还在等什么,快点赞。
我是失忆,一个热爱技术的宅男,文章有任何问题您都可以在留言中指出。欢迎大家点赞、在看、留言。