首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >替换If-Else的5种方法从入门到高级示例

替换If-Else的5种方法从入门到高级示例

作者头像
王小婷
修改于 2020-11-02 06:41:01
修改于 2020-11-02 06:41:01
5.4K0
举报
文章被收录于专栏:编程微刊编程微刊

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

它导致设计复杂,代码可读性差,并且可能导致重构困难。

但是,If-Else已成为事实上的代码分支解决方案,这确实是有道理的。这是向所有有抱负的开发人员讲授的第一件事。不幸的是,许多开发人员从来没有前进到更合适的开发实践中去。

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

在这里,我将向你展示一些技巧和模式,这些技巧和模式将终结这种可怕的做法。

每个示例的难度都会增加。

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在丹麦的四大咨询公司之一中担任高级技术顾问。他主要担任客户项目的首席开发人员和解决方案架构师。

他一直在为商业客户和政府机构开发软件,例如国防部,教育部,丹麦环境与食品部,国家警察,丹麦劳动力市场和招聘局以及Ørstad。

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
编写 if 时不带 else,你的代码会更好!
来源:翻译自:Nicklas Millard的文章《Better Software Without If-Else》
肉眼品世界
2020/11/19
9550
编写 if 时不带 else,你的代码会更好!
How to code like a pro in 2022 and avoid If-Else
在浏览文章的时候发现了一篇叙述有关if-else语句的文章,这篇文章作者是Thai Tran,他原文是用英语写的,然后看着文章浅显易懂,便尝试翻译成汉语。如有不妥还望指出。
愷龍
2022/09/26
3940
if-else泛滥成灾?这样优雅去掉后更简洁了!【粉丝答疑】
前段时间,和大家分享了一个关于如何优雅使用if-else的文章,之后陆陆续续好几个小伙伴微信给我留言聊最后那一段,说没有看明白,那么今天就来针对性的整理一下;答应粉丝的事情,必须得完成的。
一行Java
2022/04/07
6360
if-else泛滥成灾?这样优雅去掉后更简洁了!【粉丝答疑】
【React】1981- React 的 8 种条件渲染的方法
条件渲染是React中的一个强大功能,它允许开发人员根据某些条件控制组件的显示。它在创建动态和交互式用户界面方面发挥着至关重要的作用。
pingan8787
2024/03/18
1.8K0
【React】1981- React 的 8 种条件渲染的方法
别让 If-Else ,变成 “懒婆娘的裹脚布”
语句堪称程序设计领域中最为常见的控制结构之一 。在软件开发的历程中,每一位开发者都曾运用
不惑
2025/01/22
4480
别让 If-Else ,变成 “懒婆娘的裹脚布”
PHP 8.x 深入探讨PHP性能改进特性
作为一个充满激情的开发人员,我很高兴地见证了PHP这个广受赞誉的服务器端脚本语言在过去二十年中的发展。
Tinywan
2024/04/15
7630
PHP 8.x 深入探讨PHP性能改进特性
我从高级开发者身上学到的19条编码原则
『在代码中用一堆嵌套,花大量时间写出漂亮的代码但最后才发现无法运行,不给任务留缓冲时间…… 』这是很多新手程序员都踩过的雷。在这篇文章中,一位全栈首席开发者总结了高级开发人员的 19 个编码原则,可以帮助新手少踩些坑。
NewBeeNLP
2020/11/09
3850
32 条关于软件开发的建议和教训
作者 | Nicklas Millard 译者 | Sambodhi 策划 | 施尧 近几年来,我一直为大大小小的客户开发专业软件。这些软件中有一些是在非常严格的环境下使用的,安全性和可靠性是最重要的。基于多年的工作经验,我提出了一系列有用的建议和教训。以下是我整理的清单,包括建议、经验教训和最佳实践。 有时候编写一些垃圾代码也没问题。应用程序的各个部分并不是生来平等的。 不必通过学习一门新语言来学习新事物。很多相同的事情可以用多种语言来完成,宁可深而不广。 编写抛弃型代码以测试不同的方法。别把这些抛弃型代
深度学习与Python
2023/04/01
5760
32 条关于软件开发的建议和教训
代码重构(四):条件表达式重构规则
继续更新有关重构的博客,前三篇是关于类、函数和数据的重构的博客,内容还算比较充实吧。今天继续更新,本篇博客的主题是关于条件表达式的重构规则。有时候在实现比较复杂的业务逻辑时,各种条件各种嵌套。如果处理不好的话,代码看上去会非常的糟糕,而且业务逻辑看上去会非常混乱。今天就通过一些重构规则来对条件表达式进行重构,让业务逻辑更为清晰,代码更以维护和扩展。 今天博客中的代码示例依然是Swift班,在对条件表达式重构时也会提现出Swift的优雅之处,会用上Swift特有的语法及其特点,比如使用guard来取代if-l
lizelu
2018/01/11
1.8K0
代码重构(四):条件表达式重构规则
什么是pl/sql语句_过程化SQL有三种循环结构
*** PL/SQL的使用几乎贯穿于整个Oracle 的学习过程,也是作为一个初级开发人员必须掌握的重要知识点。
全栈程序员站长
2022/11/07
1.7K0
什么是pl/sql语句_过程化SQL有三种循环结构
每个 C# 开发人员都应该掌握的 5 种强大的设计模式
想象一下你正在建造一栋房子。你是更愿意使用来自专业建筑师那些经过实践检验的蓝图呢,还是从头开始绘制所有的设计图呢?软件开发也是同样的道理!设计模式是针对常见问题的经实践验证的解决方案,它们提供了清晰的蓝图,能让你的代码更高效、更可复用且更易于维护。
郑子铭
2025/02/20
2980
每个 C# 开发人员都应该掌握的 5 种强大的设计模式
函数式接口和lambda表达式优雅的替换大量的if-else
随着条件的增多,if-else块会变得越来越臃肿,维护起来也变得困难。这就是我们需要一种更优雅的替代方法的地方。
一只牛博
2025/05/31
1410
SpringBoot 中优化 if-else 语句的七种方法实战
大家好,我是默语,擅长全栈开发、运维和人工智能技术。在我的博客中,我主要分享技术教程、Bug解决方案、开发工具指南、前沿科技资讯、产品评测、使用体验、优点推广和横向对比评测等内容。今天,我们将深入探讨如何在 SpringBoot 中优化 if-else 语句。随着代码复杂性的增加,传统的 if-else 语句往往会导致代码难以维护和扩展。本文将介绍七种优化 if-else 语句的实战方法,包括策略模式、枚举与策略模式结合、多态性、Lambda 表达式与函数接口、状态模式、命令模式以及保护子句,帮助你提高代码的可读性和扩展性。💡✨
默 语
2024/11/22
4480
.NET 中50种常见错误使用方法及推荐用法
下面是一个经过改进和扩展的列表,其中包含破坏 .NET 应用程序的 50 种方法,并解释了每种做法不佳的原因,以及演示如何解决每个问题的更正代码示例。这个全面的指南将有助于识别不良做法,并说明如何编写干净、可维护的代码。
郑子铭
2024/11/29
6740
.NET 中50种常见错误使用方法及推荐用法
改善你的代码:使用这5种重构技术
本文由 Suraj Vishwakarma 撰写的博文,这篇文章讨论了如何将代码重构整合到你的编程过程中,建议你特别为重构代码分配时间,并将较大的重构问题分解为较小的问题进行处理。
前端小智@大迁世界
2023/07/09
6310
《重构》第六章 - 读后感(函数重构的9种方法)
在《重构》这本书中,第三章大概得描述了代码的问题点。所以说第六章就开始对具体的改造方法进行详细说明了。但是大概得分一下就是函数、对象、代码块等一些细节的东西,书中其实也是按照这样的过程进行重构手法的演示。这里本次还是针对函数。函数是我们编码的核心部分,因此这块也是放到了首位。按照之前的学习,函数这块的重构具体有Extract method(提炼函数)、Inline method(内联函数)、Inline Temp(内联临时变量)、replace temp with query(使用查询的方式取代临时变量)、introduce explainning(引入解释性变量)、split temporary variable(分解临时变量)、remove assignments to parameters(移除对参数的赋值)、replace method with method object(以函数对象取代函数)、substritute algorithm(替换算法),单看这些名词估计我们就已经懵了。所以咋还是逐个过一下。
写一点笔记
2022/08/11
6280
《重构》第六章 - 读后感(函数重构的9种方法)
人生充满选择,编程也是
人生在世,我们每天都需要进行三项重大选择:早餐吃什么,午餐吃什么,晚餐吃什么。这一度让我感到非常为难,于是我养成了一个习惯,只要在附近的餐馆发现了几种还不错的食物,我就会连续一段时间一直吃它们,直到吃腻,再尝试一下别的选择,直到又发现还比较对胃口的,就再一直吃,如此循环往复。
Sheepy
2018/09/10
6970
为什么if-else会影响我的代码的复杂度
我之前写了一篇文章《我用规则引擎消除if语句,提高了代码的可扩展性》,这篇文章我想阐述的观点是复杂的if语句可能会影响代码的阅读和代码的扩展性,会将非业务的条件逻辑与业务逻辑混合在一起。时间长了代码会越来越臃肿,因此这种情况下我推荐使用一些设计模式例如策略模式,责任链模式等去优化if语句带来的问题,文中我发现使用规则引擎也能实现类似效果,因此介绍了怎么使用规则引擎Easy Rules去取代if语句。
Lvshen
2022/05/05
2.2K0
为什么if-else会影响我的代码的复杂度
软件系统复杂性治理方法
本文讨论了软件复杂性及其产生原因,介绍了如何度量软件复杂性,及 SOLID 软件设计原则,并探讨管理复杂性的方法,包括使用代码重构、设计模式、领域驱动设计等。通过遵循这些原则和方法,开发人员可以降低软件复杂性,提高代码质量和可维护性。这篇文章内容涵盖了软件开发的道与术,希望能对你所有帮助,欢迎评论交流~
知一
2024/02/15
8820
SpringBoot中优化if-else语句的七种方法实战
策略模式允许在运行时选择算法的行为。它通过将算法定义成独立的类,并在运行时动态选择使用哪个算法,来避免使用多个if-else或switch语句。
公众号:码到三十五
2024/08/06
3170
相关推荐
编写 if 时不带 else,你的代码会更好!
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档