避免双重否定

来源:互联网 发布:html5商城网站源码 编辑:程序博客网 时间:2024/04/30 13:06

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

using  System.Collections.Generic;using  LosTechies.DaysOfRefactoring.SampleCode.BreakMethod.After;namespace  LosTechies.DaysOfRefactoring.SampleCode.DoubleNegative.Before{    public class  Order    {        public void  Checkout(IEnumerable<Product> products, Customer  customer)        {            if  **(!customer.IsNotFlagged)**               {                // the customer account is flagged                // log some errors and return                return;            }            // normal order processing        }    }    public class  Customer    {        public decimal  Balance { get; private set; }        public bool  IsNotFlagged        {            get  { return  Balance < 30m; }        }    }}

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

using System.Collections.Generic;using LosTechies.DaysOfRefactoring.SampleCode.BreakMethod.After;namespace LosTechies.DaysOfRefactoring.SampleCode.DoubleNegative.After{    public class Order    {        public void Checkout(IEnumerable<Product> products, Customer customer)        {            if (customer.IsFlagged)            {                // the customer account is flagged                // log some errors and return                return;            }            // normal order processing        }    }    public class Customer    {        public decimal Balance { get; private set; }        public bool IsFlagged        {            get { return Balance >= 30m; }        }    }}

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

0 0
原创粉丝点击