重构指南 - 分解复杂判断(Remove Arrowhead Antipattern)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了重构指南 - 分解复杂判断(Remove Arrowhead Antipattern)相关的知识,希望对你有一定的参考价值。

当代码中有多层嵌套时,会降低代码的可读性,对于以后的修改也增加难度,所以我们需要分解复杂的判断并尽快返回。

重构前代码

public class Security
{
    public ISecurityChecker SecurityChecker { get; set; }

    public Security(ISecurityChecker securityChecker)
    {
        SecurityChecker = securityChecker;
    }

    public bool HasAccess(User user, Permission permission, IEnumerable<Permission> exemptions)
    {
        bool hasPermission = false;

        if (user != null)
        {
            if (permission != null)
            {
                if (exemptions.Count() == 0)
                {
                    if (SecurityChecker.CheckPermission(user, permission) || exemptions.Contains(permission))
                    {
                        hasPermission = true;
                    }
                }
            }
        }

        return hasPermission;
    }
}

 

重构后代码

public class Security
{
    public ISecurityChecker SecurityChecker { get; set; }

    public Security(ISecurityChecker securityChecker)
    {
        SecurityChecker = securityChecker;
    }

    public bool HasAccess(User user, Permission permission, IEnumerable<Permission> exemptions)
    {
        if (user == null || permission == null)
            return false;

        if (exemptions.Contains(permission))
            return true;

        return SecurityChecker.CheckPermission(user, permission);
    }
}

 

重构后的代码,大大提高了可读性和以后的可维护性。

 

以上是关于重构指南 - 分解复杂判断(Remove Arrowhead Antipattern)的主要内容,如果未能解决你的问题,请参考以下文章

小酌重构系列[19]——分解大括号

重构手法之简化条件表达式

代码重构终极指南!!

代码重构终极指南!!

重构.改善既有代码的设计9简化条件表达式

《重构与模式》简化-积木系列