重新组织数据之九 :Replace Magic Number with Symbolic Constant(以符号常量/字面常量取代魔法数)

你有一个字面数值(literal number ),带有特别含义。

创造一个常量,根据其意义为它命名,并将上述的字面数值替换为这个常量。

   double potentialEnergy(double mass, double height) {

       return mass * 9.81 * height;

   }

 

   double potentialEnergy(double mass, double height) {

       return mass * GRAVITATIONAL_CONSTANT * height;

   }

   static final double GRAVITATIONAL_CONSTANT = 9.81;

动机(Motivation)

在计算科学中,魔法数(magic number)是历史最悠久的不良现象之一。所谓魔法数是指拥有特殊意义,却又不能明确表现出这种意义的数字。如果你需要在不同的地点引用同一个逻辑数,魔法数会让你烦恼不已,因为一旦这些数发生改变,你就必须在程序中找到所有魔法数,并将它们全部修改一遍,这简直就是一场噩梦。就 算你不需要修改,要准确指出每个魔法数的用途,也会让你颇费脑筋。

许多语言都允许你声明常量。常量不会造成任何性能开销,却可以大大提高代码的可读性。

进行本项重构之前,你应该先寻找其他替换方案。你应该观察魔法数如何被使用,而后往往你会发现一种更好的使用方式。如果这个魔法数是个type code(型别码), 请考虑使用Replace Type Code with Class;如果这个魔法数代表一个数组的长度,请在遍历该数组的时候,改用Array.length()。

作法(Mechanics)

·声明一个常量,令其值为原本的魔法数值。

·找出这个魔法数的所有引用点。

·检查是否可以使用这个新声明的常量来替换该魔法数。如果可以,便以此一常量替换之。

·编译。

·所有魔法数都被替换完毕后,编译并测试。此时整个程序应该运转如常,就像没有做任何修改一样。

Ø有个不错的测试办法:检查现在的程序是否可以被你轻松地修改常量值(这可能意味某些预期结果将有所改变,以配合这一新值。实际工作中并非总是可以进行这样的测试)。如果可行,这就是一个不错的手法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值