NO.57 代码优化初步 2.公共规则的抽取、可配置化

  有一天进行代码走查,发现这段代码出现在4个类中,一字不差——

1.很明显:Ctrl+CCtrl+V的;类似的规则如果发生变化或者就是笔误哪个地方写错了,难道要去改4处?
2.同变量判断,却全用的if判断,把每种情况都变成最坏情况。

1次改进:

1.使用了else if 做了一下小小的改进
2.方法改为static了,也把它放在一个规则类里了
但是不是感觉还是很笨拙?

2次改进:

对于这种大量的常量映射,可以使用java.util.Properties
不过修改起来还是不方便...

3次改进:  把这些配置信息放进一个CurrencyProp.properties文件中,文件和CurrencyRules.java放在同一个目录:

然后那个CurrencyRules中的static块就变成这个样子——

   至此,一段公共规则被抽取出来了,并且易于配置。
   不过如果希望规则修改后实时生效,可以放弃static方式而使用实例化方式,大家可以自己试着实现一下。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值