软件设计重构秘笈26式-25避免双重否定

软件设计重构秘笈26式-25避免双重否定

概念

本文中的”避免双重否定”是指把代码中的双重否定语句修改成简单的肯定语句,这样即让代码可读,同时也给维护带来了方便。

意图

避免双重否定重构本身非常容易实现,但我们却在太多的代码中见过因为双重否定降低了代码的可读性以致于非常让人容易误解真正意图。
存在双重否定的代码具有非常大的危害性,因为这种类型的代码容易引起错误的假设,
错误的假设又会导致书写出错误的维护代码,最终会导致bug产生。具体可以看下面的代码:

案例

public class Order {

    public void  checkout(List<Product> products, Customer  customer)
    {
        if  (!customer.isNotFlagged()) // 双重否定
        {
            // the customer account is flagged
            // log some errors and return
            return;
        }

        // normal order processing
    }

}

public class Customer {

    private double balance;

    public boolean isNotFlagged() {
        return balance < 300;
    }

    public double getBalance() {
        return balance;
    }

    public void setBalance(double balance) {
        this.balance = balance;
    }
}

public class Product {
}


重构

如上代码中的双重否定可读性非常低,因为我们很难搞明白双重否定的正确值。要重构它也非常容易,如下是重构后的代码:

public class Order {

    public void  checkout(List<Product> products, Customer  customer)
    {
        if  (customer.isFlagged())
        {
            // the customer account is flagged
            // log some errors and return
            return;
        }

        // normal order processing
    }

}

public class Customer {

    private double balance;

    public boolean isFlagged() {
        return balance >= 300;
    }

    public double getBalance() {
        return balance;
    }

    public void setBalance(double balance) {
        this.balance = balance;
    }
}

总结

”双重否定“很容易让人产生错误的判断,也很难让人理解你的代码,所以这个重构在我们的代码中是很重要的,尤其是在判断条件很多且业务复杂的时候。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值