今天同事那边需要个小工具,需要一个在进行定长通讯时,把响应和请求报文根据各字段长度截取出来。
逻辑很简单,一个小时左右就写了个小demo出来。
因为最近刚好在学习面向对象,想着就以面向对象的思想来优化下这个demo,也和大家交流下,还能怎么优化!
这是项目刚开始的目录,因为是在公司写的,直接把包发回来了,先从目录开始优化把。
按照我们java的规范,先根据模块区分出来。
简单区分完,大概是这个样子的,因为没有用其他的jar包,也就没建resource目录和test目录。
service里面的四个类是四个接口,因为四个接口的报文字段长度都不同,也有想过将四个接口合成一个类,类里写四个方法去处理逻辑,但想了一下还是分开比较好,这样就算其中一个接口的字段长度发生了变化需要更改,也只需要改这个接口的类,这样耦合度更小些,更符合面向对象的思想。
四个接口每个都有自己的请求报文实体类,messageRequest,响应报文实体类可以共用,就建了一个。
但发现了一个问题,每个接口的前几个字段都一样,发生了重复代码。也就意味着我们定义的实体类中这几个字段也是重复的。
那我们就把这些重复代码提出来,提到公共的地方,可以是继承,可以用接口,是用抽象类还是接口呢,其实很简单的一个概念就是用 is-a 和 has-a区分。或者说去想抽象类和接口的概念,抽象类就是将共同的、共有的属性提取出来,统一写在一个地方,也就是面向对象三大特性之一的继承,而接口是将相同的方法抽象出来,可能多个对象具有相同的方法,但每个对象的实现方式又不同,比如说我们这个demo的四个方法,都有testReqString这个方法,都是为了将字段长度截取出来,但每个对象的字段长度不同。
这个逻辑理清的话,我们就可以把实体类中公共的属性抽象成抽象类,把service中公共方法抽象成接口,试下吧。
注意,父类的属性如果是private的话,子类虽然可以继承,但是是没有使用权的。
先看下没抽取之前的实体类:
package com.xnew.demo.StringDemo.agentPaymentQuery;
/*
* 支付状态查询
*
* */
public class MsgReq {
//报文头 10位
private String MSGHEADER;
//交易代码 5位
private String TRADECODE;
//交易来源 1位
private String TRADESOURCE;
//地区号 5位
private String ADDRESSCODE;
//网点号 5位
private String WEBSITECODE;
//柜员号 5位
private String TELLERCODE;
//商户交易流水号 16位
private String TRADESEQNO;
//商户编号 12位
private String MERCHAN