简单易懂的Builder模式

简单易懂的Builder模式

这天你刚刚打卡上班,开启电脑,打开eclipse,登陆qq,进入qq群,正准备跟群友摸一天的鱼.突然你的老板跑到你身边给了你个任务:

1.1给前端一个接口,根据前端传入的orderid返回整个订单的详情,简单,你抬抬手就写完了代码,将订单表中的数据拿出来返回给前端了;

数据库信息:简单易懂的Builder模式

前台数据:

{"id":1,"detail":"秃驴是个大帅哥","state":"1"}



1.2正当你要继续摸鱼的时候,前端跑过来说:”大哥,你能不能把订单状态(state)的返回值搞成中文啊?”

“好说”,我们直接定义一个用于专门用于返回给前端的实体类,将数据转换后再丢给前端;

public class OrderInfo {
	private Integer id;
	private String state;

	public OrderInfo(Integer id,String state){
		this.id=id;
		this.state=state;
	}
	...
}


前端数据:

{"id":1,"detail":"秃驴是个大帅哥","state":"交易状态"}

1.3需求怎么可能就改一次!这不,前端又让加个state_code参数好让他根据state(订单状态)的值做不同动作,这也不难;

返回实体类的属性:

	private Integer id;
	private String state;
	private String state_code;

前端数据:

{"id":1,"state":"1","state_code":"交易状态"}

关键代码:

			String stateCode = order.getState();
			orderInfo.setState_code(stateCode);
			String state = null;
			switch (stateCode) {
				case "0":
					state = "创建状态";
					break;
				case "1":
					state = "交易状态";
					break;
				case "2":
					state = "完成状态";
					break;
			}
			orderInfo.setState(state)

1.4该需求这种事怎么会只有前端改,所以项目经理提了他的要求:”给order表价加个state_pay(付款状态),也返给前端吧.”

于是我们又改:

			String stateCode = order.getState();
			orderInfo.setState_code(stateCode);
			...
			orderInfo.setState(state);

			String payStateCode = order.getStatePay();
			orderInfo.setPay_state_code(payStateCode);
			String payState = null;
			switch (payStateCode) {
				case "0":
					payState = "待付款";
					break;
				case "1":
					payState = "付款中";
					break;
				case "2":
					payState = "已付款";
					break;
			}
			orderInfo.setPay_state(payState);

前台数据:

{"id":1,"state":"交易状态","state_code":"1","pay_state":"付款中","pay_state_code":"1"}

2.1前端一看这不行啊,我本来判断一个值就好了,这下要一下子判断2个值,ifelse这不得搞好多个啊,就跟我们要求只要一个状态:    

state=0 state_pay=0 => status :待交易 code: 0
state=0 state_pay=1 => status :预交易 code: 1
state=1 state_pay=2 => status :交易中 code: 2
state=2 state_pay=2 => status :已交易 code: 3

好家伙,这么改来改去自己后台代码也得各种ifelse不说,每次修改,都得修改一大坨代码,以后维护自己看了都头大,有没有什么好方法让自己的代码更优雅易读呢?

Builder设计模式专门为这种场合使用!

现在我们以builder模式改造我们的返回实体类:

public class OrderInfo {
	private Integer id;
	private String status;
	private String code;

	public static class Builder {
		private OrderInfo order;

		private String state;
		private String payState;

		public Builder() {
			order = new OrderInfo();
		}
		public Builder state(String state) {
			this.state = state;
			return this;
		}
		public Builder pay(String payState) {
			this.payState = payState;
			return this;
		}
		public OrderInfo build() {
			//在build()里进行构建order对象
			switch (this.state) {
				case "2":
					order.setCode("3");
					order.setStatus("已交♂易");
					break;
				case "1":
					order.setCode("2");
					order.setStatus("交♂易中");
					break;
				case "0":
					switch (payState) {
						case "1":
							order.setCode("1");
							order.setStatus("预交♂易");
							break;
						case "0":
							order.setCode("0");
							order.setStatus("待交♂易");
							break;
					}
					break;
			}
			return order;
		}
	}

	//只允许builder创建新对象
	private OrderInfo() {
	}
	public Integer getId() {
		return id;
	}
	public String getStatus() {
		return status;
	}
	public String getCode() {
		return code;
	}
	public void setId(Integer id) {
		this.id = id;
	}

	private void setStatus(String status) {
		this.status = status;
	}

	private void setCode(String code) {
		this.code = code;
	}
}

@service层关键代码:

			Order order = ...
			OrderInfo orderInfo = new OrderInfo.Builder()
							.state(order.getState())
							.pay(order.getStatePay())
							.build();
			orderInfo.setId(order.getId());
			return orderInfo;

这里Builder把原先需要在service层进行的逻辑判断移到了自身的builder方法中,如果以后又要更改状态或者逻辑的话service层可以不改动或者很小,只改动OrderInfo的内部类Builder就可以了,而且整个代码看起来也更清晰;感觉整个人都优雅了起来呢;

2.2所以当项目经理来告诉我们要再加个state_express(快递状态)的时候,

state=0 state_pay=0  state_express=0 => status :待交易 code: 0
state=0 state_pay=1  state_express=0 => status :预交易 code: 1
state=1 state_pay=2  state_express=0 => status :待发货 code: 2
state=1 state_pay=2  state_express=1 => status :运送中 code: 3
state=2 state_pay=2  state_express=2 => status :已完成 code: 4

我们不仅没打死项目经理,而且简单易懂的Builder模式

转载于:https://my.oschina.net/imsorry/blog/3016430

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101073.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 电阻电容电感的常用标注方法(手机电容和电阻的区分)

    认识电容及电容电阻的标注   一、认识电容及电容的标注①电容的功能和表示方法。由两个金属极,中间夹有绝缘介质构成。电容的特性主要是隔直流通交流,因此多用于级间耦合、滤波、去耦、旁路及信号调谐。电容在电路中用“C”加数字表示,比如C8,表示在电路中编号为8的电容。②电容的分类。电容按介质不同分为:气体介质电容,液体介质电容,无机固体介质电容,有机固体介质电容电解电容。按极性分为:有极性电容和无极性电

    2022年4月12日
    136
  • 域名与优化之间的联系[通俗易懂]

    域名与优化之间的联系[通俗易懂]什么域名有利于网站优化?域名与网站优化有什么的关系?域名与网站优化有关系吗?很多人不知道域名的好坏其实与网站优化也是有着联系的,什么样的域名对于网站优化有好处呢?今天这篇文章外链代发SEO就来给各位介绍一下关于域名与网站优化的关系。可能有的新站长对于域名与网站优化之间的关系不是很清楚,其实域名的挑选对网站企业的发展有着重要的影响和含义,一个好的域名不只使网民简单记,并且对企业的品牌宣扬有着非常重…

    2022年5月17日
    56
  • Java 中的三大特性(超详细篇)

    Java 中的三大特性(超详细篇)简介Java的三大特性:封装、继承、多态乍一听,好像很高大上,其实当你真正用的时候,会发现高大上的还在后面呢。。。热身在正式讲解三大特性之前,先普及几个知识1.访问权限修饰符Java中关于访问权限的四个修饰符,表格如下 private friendly(默认) protected public 当前类访问权限 √ √ √ √ 包访问权限 × √ √ √ 子类访问权限 × × √

    2022年7月7日
    23
  • centos7.4安装docker_pythondocker

    centos7.4安装docker_pythondocker前言当我们在一台电脑上搭建了python3.6的环境,下次换台电脑,又得重新搭建一次,设置环境变量等操作。好不容易安装好,一会提示pip不是内部或外部命令,一会又提示pip:commandno

    2022年7月31日
    5
  • 二维图形旋转公式的推导

    二维图形旋转公式的推导

    2022年1月22日
    57
  • 商标注册_企业软件

    商标注册_企业软件开发软件时,当用到商业用途时,注册码与激活码就显得很重要了。现在的软件激活成功教程技术实在在强了,各种国内外大型软件都有注册机制,但同时也不断地被激活成功教程。下面发的只是一个常用版本,发出源码被破就更容易了,但我们学习的是技术。当然也为以后自己的软件不会被轻易激活成功教程。第一步。根据卷标,CPU序列号,生成机器码//取得设备硬盘的卷标号       publicstaticstringG

    2022年9月1日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号