当前位置 : 主页 > 编程语言 > java >

(5/8)枚举的错误用法 之 方法体内部

来源:互联网 收集:自由互联 发布时间:2022-07-07
继续讲枚举的使用。前文阐释了方法请求参数、方法返回值、POJO属性定义成枚举类型的好处。本文讲在方法里使用枚举的妙处。 【先上代码】 private boolean riskCheck(RefundReqBO refundReq, Re


 

 

继续讲枚举的使用。前文阐释了方法请求参数、方法返回值、POJO属性定义成枚举类型的好处。本文讲在方法里使用枚举的妙处。

【先上代码】

private boolean riskCheck(RefundReqBO refundReq, RefundRspBO refundRsp, RpmOrdDO rpmOrd, RpmRtulDO rpmRtul, YGBizMessageContext ctx) throws YGException {
Logger logger = YGLogger.getLogger();
... ...

String busTyp = RRCBusTypEnum.USER_CONSUME_REFUND_REFUND.getValue();
if(AcPayFlgEnum.NO_ACCOUNT_PAYMENT.getValue().equals(rpmOrd.getAcPayFlg())){
busTyp = RRCBusTypEnum.GWAY_CONSUME_REFUND.getValue();
}

RealTimeRiskCheckReqBO riskReq = new RealTimeRiskCheckReqBO();
riskReq.setTxCd(refundReq.getGda().getTxCd());
... ...
/** 此处省略15行代码 **/
... ...
riskReq.setBusTyp(busTyp);
... ...
}

 

本文要说的就是上面方法里busTyp变量的类型。

注意上面方法里省略的15行代码 ,正是这么多行逻辑代码的存在,当我们滚屏时,会给我们理解下文里出现的busTyp带来麻烦:busTyp具体指?又会有哪些值? 用我的14寸的笔记本电脑截屏如下,可以直观地看到,一屏显示不全这个变量的定义和使用。

(5/8)枚举的错误用法 之 方法体内部_代码整洁

 

【重构方式】

在上面的方法体里,把busTyp定义为了String,由于代码行多,在下文看到这个变量后,因为是字符串,所以难免不知道它是会存哪些值。这时呢,我们只好再翻上面的代码查看它的定义和赋了哪些值。

而如果把busTyp定义为RRCBusTypEnum,那么下文在用到的时候,就能直观的知道它的含义以及它的具体取值范围,从而提高了可读性。 

BTW,不管存不存在那15行代码,把busTyp定义为RRCBusTypEnum,用的时候再取它对应的属性,这无疑是个好的编程习惯,因为代码整洁度高!

重构后的代码为:

private boolean riskCheck(RefundReqBO refundReq, RefundRspBO refundRsp, RpmOrdDO rpmOrd, RpmRtulDO rpmRtul, YGBizMessageContext ctx) throws YGException {
Logger logger = YGLogger.getLogger();
... ...

RRCBusTypEnum busTyp = RRCBusTypEnum.USER_CONSUME_REFUND_REFUND;
if(AcPayFlgEnum.NO_ACCOUNT_PAYMENT.getValue().equals(rpmOrd.getAcPayFlg())){
busTyp = RRCBusTypEnum.GWAY_CONSUME_REFUND;
}

RealTimeRiskCheckReqBO riskReq = new RealTimeRiskCheckReqBO();
riskReq.setTxCd(refundReq.getGda().getTxCd());
... ...
/** 此处省略15行代码 **/
... ...
riskReq.setBusTyp(busTyp.getValue());
... ...
}

 

网友评论