• 31天重构学习笔记16. 封装条件


    概念:本文中的“封装条件”是指条件关系比较复杂时,代码的可读性会比较差,所以这时我们应当根据条件表达式是否需要参数将条件表达式提取成可读性更好的属性或者方法,如果条件表达式不需要参数则可以提取成属性,如果条件表达式需要参数则可以提取成方法。

    正文:如下代码所示,PerformCoolFunction里面的if条件判断比较复杂,看起来有点杂乱,所以就把它提出来。

    using System;

    namespace LosTechies.DaysOfRefactoring.EncapsulateConditional.Before
    {
    public class RemoteControl
    {
    private string[] Functions { get; set; }
    private string Name { get; set; }
    private int CreatedYear { get; set; }

    public string PerformCoolFunction(string buttonPressed)
    {
    // Determine if we are controlling some extra function
    // that requires special conditions
    if (Functions.Length > 1 && Name == "RCA" && CreatedYear > DateTime.Now.Year - 2)
    return "doSomething";
    }
    }
    }

    如下代码所示,我们把条件表达式封装成HasExtraFunctions属性,这样先前的条件判断就成了if (HasExtraFunctions) ,所以这样就在很大程度上提高了可读性。

    using System;

    namespace LosTechies.DaysOfRefactoring.EncapsulateConditional.After
    {
    public class RemoteControl
    {
    private string[] Functions { get; set; }
    private string Name { get; set; }
    private int CreatedYear { get; set; }

    private bool HasExtraFunctions
    {
    get { return Functions.Length > 1 && Name == "RCA" && CreatedYear > DateTime.Now.Year - 2; }
    }

    public string PerformCoolFunction(string buttonPressed)
    {
    // Determine if we are controlling some extra function
    // that requires special conditions
    if (HasExtraFunctions)
    return "doSomething";
    }
    }
    }

    总结:这个重构在很大程度上能改善代码的可读性,尤其是在一个逻辑很复杂的应用中,把这些条件判断封装成一个有意义的名字,这样很复杂的逻辑也会立刻变得简单起来。

  • 相关阅读:
    查询中常用的扩展方法
    加载关联表的数据 显式加载
    加载关联表的数据 延迟加载
    加载关联表的数据 贪婪加载
    操作内存中的数据
    DBContext基础查询
    EF简单增删改查
    1- MySQL数据库基础快速入门
    1-3 Postman 注册账号与登录
    1-2 postman工具简介
  • 原文地址:https://www.cnblogs.com/ywsoftware/p/2892599.html
Copyright © 2020-2023  润新知