zoukankan      html  css  js  c++  java
  • 31天重构学习笔记26. 避免双重否定

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

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

     

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

  • 相关阅读:
    Web Api跨域访问配置及调用示例
    EasyUI datagrid 日期时间格式化
    bootstrap-table组合表头
    Tomcat version 7.0 only supports J2EE 1.2, 1.3, 1.4, and Java EE 5 and 6 Web mod
    Java 开发环境配置
    一台电脑上配置多个tomcat
    使用plsql Developer 连接远程服务器
    阿里云初识
    算法入门———冒泡排序
    算法入门———递归
  • 原文地址:https://www.cnblogs.com/ywsoftware/p/2892626.html
Copyright © 2011-2022 走看看