编写 if 时不带 else,你的代码会更好

在这里插入图片描述 设计更好的软件,替换If-Else的5种方法。入门到高级示例测试

让我直接说这句话:If-Else一般是一个糟糕的选择。编码

它致使设计复杂,代码可读性差,而且可能致使重构困难。翻译

可是,If-Else已成为事实上的代码分支解决方案,这确实是有道理的。这是向全部有抱负的开发人员讲授的第一件事。不幸的是,许多开发人员历来没有前进到更合适的分支策略。设计

有些人的口头禅是:If-Else是一把锤子,一切都是钉子。3d

没法区分什么时候使用更合适的方法是区分大三学生和大三学生的缘由之一。对象

我将向您展现一些技巧和模式,这些技巧和模式将终结这种可怕的作法。blog

每一个示例的难度都会增长。接口

1 彻底没必要要的Else块图片

这也许是那些初级开发人员最负罪的之一。下面的示例很好地说明了当您被认为If-Else很棒时会发生什么。 在这里插入图片描述 Simple if-else 只需删除else`块便可简化此过程。 在这里插入图片描述 Removed else 看起来更专业吧?开发

您会常常发现,实际上根本不须要其余块。像在这种状况下同样,您想要在知足特定条件的状况下执行某些操做并当即返回。

2 价值分配

若是您要根据提供的某些输入为变量分配新值,请中止If-Else废话-一种更具可读性的方法。 在这里插入图片描述 Value assignment with if-else 尽管很简单,但它却很糟糕。首先,If-Else很容易在这里被开关取代。可是,咱们能够经过彻底删除else来进一步简化此代码。 在这里插入图片描述 If statements with fast return 若是不使用else,则咱们将剩下干净的可读代码。请注意,我也将样式更改成快速返回而不是单返回语句-若是已经找到正确的值,继续测试一个值根本没有意义。

3 前提条件检查

一般,我发现,若是方法提供了无效的值,则继续执行是没有意义的。 假设咱们从之前就有了DefineGender方法,要求提供的输入值必须始终为0或1。 在这里插入图片描述 Method without value checks 在没有价值验证的状况下执行该方法没有任何意义。所以,在容许方法继续执行以前,咱们须要检查一些先决条件。

应用保护子句防护性编码技术,您将检查方法的输入值,而后继续执行方法。 在这里插入图片描述 Check preconditions with guard clauses 至此,咱们确保仅在值落在预期范围内时才执行主逻辑。 如今,IF也已被三元代替,由于再也不须要在结尾处默认返回"未知"。

4 将If-Else转换为字典—彻底避免If-Else

假设您须要执行一些操做,这些操做将根据某些条件进行选择,咱们知道之后必须添加更多操做。 在这里插入图片描述 也许有人倾向于使用久经考验的If-Else。若是添加新操做,则只需简单地添加其余内容便可。很简单 可是,就维护而言,这种方法不是一个好的设计。

知道咱们之后须要添加新的操做后,咱们能够将If-Else重构为字典。 在这里插入图片描述 可读性已大大提升,而且能够更轻松地推断出该代码。 注意,仅出于说明目的将字典放置在方法内部。您可能但愿从其余地方提供它。

5 扩展应用程序—彻底避免使用If-Else

这是一个稍微高级的示例。

经过用对象替换它们,知道什么时候甚至彻底消除If。

一般,您会发现本身不得不扩展应用程序的某些部分。做为初级开发人员,您可能会倾向于经过添加额外的If-Else(即else-if)语句来作到这一点。

举这个说明性的例子。在这里,咱们须要将Order实例显示为字符串。首先,咱们只有两种字符串表示形式:JSON和纯文本。在此阶段使用If-Else并非什么大问题,若是咱们能够轻松替换其余,只要如前所述便可。 在这里插入图片描述 知道咱们须要扩展应用程序的这一部分,这种方法绝对是不可接受的。

上面的代码不只违反了"打开/关闭"原则,并且阅读得很差,还会引发可维护性方面的麻烦。

正确的方法是遵循SOLID原则的方法-咱们经过实施动态类型发现过程(在本例中为策略模式)来作到这一点。

重构这个混乱的过程的过程以下:

  • 使用公共接口将每一个分支提取到单独的策略类中
  • 动态查找实现通用接口的全部类
  • 根据输入决定执行哪一种策略

替换上面示例的代码以下所示。是的,这是更多代码的方式。它要求您了解类型发现的工做原理。可是动态扩展应用程序是一个高级主题。

我只显示将替换If-Else示例的确切部分。若是要查看全部涉及的对象,请查看此要点。 在这里插入图片描述 让咱们快速浏览一下代码。

方法签名保持不变,由于调用者不须要了解咱们的重构。

首先,获取实现通用接口IOrderOutputStrategy的程序集中的全部类型。而后,咱们创建一个字典,格式化程序的displayName的名称为key,类型为value。

而后从字典中选择格式化程序类型,而后尝试实例化策略对象。

最后,调用策略对象的ConvertOrderToString。

(本文翻译自Nicklas Millard的文章《Better Software Without If-Else》,参考:https://medium.com/swlh/5-ways-to-replace-if-else-statements-857c0ff19357)

相关文章
相关标签/搜索