是时候和else关键字说再见了……

IT科技类资讯2025-11-05 14:07:3143

本文转载自公众号“读芯术”(ID:AI_Discovery)

没有程序员不知道else关键字,时候说再If-else几乎遍布于所有编程语言,键字这种简单的时候说再条件逻辑使所有人都很容易理解。

但优秀程序员的键字标志是,不使用这个关键字。时候说再

笔者在开始编程的键字时候,最大错误之一是时候说再在编写条件句时过度使用else关键字,早五年前笔者就告别else了。键字

原因何在呢?时候说再

想一下else是什么意思,其意为“如果满足A就执行这个,键字如果不满足A就执行那个”。时候说再

图源:bevnet

如果A是键字二进制,就不存在问题——因为只存在两种情况。时候说再

但是键字如果A是二进制变量的集合,或者包含着更大的时候说再变量,出现问题的机会就可能会出乎意料的大,且难以理解、测试和维护。

避免if/else if,只使用if语句,亿华云计算花时间确保if组的输入条件是互斥的,这样答案就不依赖于执行顺序了。

使用switch — case语句 使用多态性处理复杂的条件情况,使代码更像状态模式。 其保证了主要的执行通道,且有着更少的特殊情况。 其迫使编程人员在每个函数开始时写入处理数据所需的所有条件。

示例

例子是这样的:一个信号灯(即信号灯对象)有着三种不同的状态,红色、黄色和绿色,每种状态都有着其自己的一系列规则。规则如下:

假设信号灯目前是红色,则在一定延迟后,状态由红转绿。 然后在另一个延迟之后,状态由绿转黄。 短暂延迟后,状态由黄转红。 不断循环

不要使用if-else关键字

constLightState= {            GREEN: 0,            YELLOW: 1,            RED: 2          }                       varTrafficLight=function () {                         var count =0                          // default state = red            var currentState =0;                        this.change=function(state) {              if (count++ >= 10 ) return              currentState = state              this.go(currentState)            }            this.go=function(state) {              if (currentState ==LightState.GREEN) {                console.log("Green -->for 1 minute")                this.change(LightState.YELLOW)              }              elseif (currentState ==LightState.YELLOW) {                console.log("Yellow -->for 10 seconds")                this.change(LightState.RED)              } elseif (currentState ==LightState.RED) {                console.log("Red -->for 1 minute");                this.change(LightState.GREEN)              } else {                throwError("Invalid State")              }            }            this.start=function() {              this.change(LightState.GREEN)            }          } 

更简单的方式

来看看不用else该怎么做:

this.go=function (state) {             if (currentState ==LightState.GREEN) {               console.log("Green -->for 1 minute")               this.change(LightState.YELLOW)             }             if (currentState ==LightState.YELLOW) {               console.log("Yellow -->for 10 seconds")               this.change(LightState.RED)             }             if (currentState ==LightState.RED) {               console.log("Red -->for 1 minute");               this.change(LightState.GREEN)             }             if (currentState != LightState.GREEN&& currentState != LightState.RED&& currentState != LightState.YELLOW) {               throwError("Invalid State")             }         } 

或者可以用一个switch代替,亿华云不得不合并不同的场景时,它看起来干净得多,而if-else很快就会失控。

若干场景良好的情况下,switch 语句可能会比if-else语句更快。

this.go=function (state) {             if (currentState ==LightState.GREEN) {               console.log("Green -->for 1 minute")               this.change(LightState.YELLOW)             }             if (currentState ==LightState.YELLOW) {               console.log("Yellow -->for 10 seconds")               this.change(LightState.RED)             }             if (currentState ==LightState.RED) {               console.log("Red -->for 1 minute");               this.change(LightState.GREEN)             }             if (currentState != LightState.GREEN&& currentState != LightState.RED&& currentState != LightState.YELLOW) {               throwError("Invalid State")             }         } 

可以使用状态模式删除这些代码中的所有if-else关键字

图源:unsplash

在这里,引入了许多if-else block/switch语句来保护各种条件,这个状态模式适合这样的场景。它允许对象根据当前的状态有不同的行为,并且用户可以定义状态特定的行为。

在这种模式下,开始考虑信号灯的可能状态,然后相应地隔离代码。

对于状态特定的行为,需要有单独的对象。 信号灯中定义的操作将行为委托给当前状态的对象。 状态本身触发状态转换

信号灯:Green(1 minute) → Yellow (10 seconds)→ Red (1 minute)

varTrafficLight=function () {                              var count =0                              // default state =green                var currentState =newGreen(this);                               this.change=function (state) {                    // limits number of changes                    if (count++ >= 10) return;                    currentState = state;                    currentState.go();                }                this.start=function () {                    currentState.go();                }            }                            varRed=function (light) {                this.light= light                              this.go=function () {                    console.log(("Red -->for 1 minute"))                    light.change(newGreen(light));                }            }                            varYellow=function (light) {                this.light= light;                this.go=function () {                    console.log("Yellow -->for 10 seconds")                    light.change(newRed(light));                }            };                              varGreen=function (light) {                this.light= light;                this.go=function () {                    console.log("Green -->for 1 minute");                    light.change(newYellow(light));                }            }; 

输出如下:

Green → for 1 minute Yellow → for 10 seconds Red → for 1 minute Green → for 1 minute Yellow → for 10 seconds Red → for 1 minute Green → for 1 minute Yellow → for 10 seconds Red → for 1 minute Green → for 1 minute Yellow → for 10 seconds 

好代码与糟糕代码的区别在哪,你get到了吗?

本文地址:http://www.bzuk.cn/html/333e32099346.html
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

热门文章

全站热门

Nginx (engine-x)是一个开源的高性能 HTTP 服务器、反向代理和 IMAP/POP3 代理服务器。nginx 杰出的功能有:稳定、丰富的功能集、简单的配置和低资源消耗。nginx 被用于一些高性能网站并在站长之间变得越来越流行。本教程会从源码构建一个带有 google paespeed 模块的用于 Ubuntu 15.04 的 nginx .deb 安装包。pagespeed 是一个由 google 开发的 web 服务器模块来加速网站响应时间、优化 html 和减少页面加载时间。ngx_pagespeed 的功能如下: 图像优化:去除元数据、动态缩放、重压缩。 CSS 与 JavaScript 压缩、串联、内联、外联。 小资源内联 图像与 JavaScript 延迟加载 HTML 重写 缓存生命期插件前置要求 Ubuntu Server 15.04 64位 root 权限该文我们将要: 安装必备软件包 安装带 ngx_pagespeed 的 nginx 测试安装必备包复制代码代码如下:sudo apt-get install dpkg-dev build-essential zlib1g-dev libpcre3 libpcre3-dev安装带 ngx_pagespeed 的 nginx第一步 - 添加nginx仓库复制代码代码如下: vim /etc/apt/sources.list.d/nginx.list加入下面的行:复制代码代码如下:deb http://nginx.org/packages/ubuntu/ trusty nginx deb-src http://nginx.org/packages/ubuntu/ trusty nginx更新仓库:复制代码代码如下:sudo apt-get update注意:假如你看到信息:GPG error [...] NO_PUBKEY [...] 等等请添加key:复制代码代码如下:sudo sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys KEYNUMBER sudo apt-get update第二步 - 从仓库下载 nginx 1.8复制代码代码如下: sudo su cd ~ mkdir -p ~/new/nginx_source/ cd ~/new/nginx_source/ apt-get source nginx apt-get build-dep nginx第三步 - 下载 Pagespeed复制代码代码如下:cd ~ mkdir -p ~/new/ngx_pagespeed/ cd ~/new/ngx_pagespeed/ ngx_version=1.9.32.3 wget https://github.com/pagespeed/ngx_pagespeed/archive/release-${ngx_version}-beta.zip unzip release-${ngx_version}-beta.zip cd ngx_pagespeed-release-1.9.32.3-beta/ wget https://dl.google.com/dl/page-speed/psol/${ngx_version}.tar.gz tar -xzf 1.9.32.3.tar.gz第四步 - 配置 nginx 来编译 Pagespeed复制代码代码如下:cd ~/new/nginx_source/nginx-1.8.0/debin/ vim rules在两处 CFLAGS .configure 下添加模块: --add-module=../../ngx_pagespeed/ngx_pagespeed-release-1.9.32.3-beta adding pagespeed to nginx adding pagespeed to nginx  第五步 - 打包 nginx 软件包并安装复制代码代码如下:cd ~/new/nginx_source/nginx-1.8.0/ dpkg-buildpackage -bdpkg-buildpackage 会编译 ~/new/ngix_source/ 为 nginx.deb。打包完成后,看一下目录:复制代码代码如下:cd ~/new/ngix_source/ ls nginx builded with pagespeed    接着安装 nginx。复制代码代码如下:dpkg -i nginx_1.8.0-1~trusty_amd64.deb    测试运行 nginx -V 测试 nginx 是否已经自带 ngx_pagespeed。复制代码代码如下:nginx -V   总结稳定、快速、开源的 nginx 支持许多不同的优化模块。这其中之一是 google 开发的‘pagespeed’。不像 apache,nginx 模块不是动态加载的,因此你必须在编译之前就选择好需要的模块。

魅族Pro6照相功力如何?(探秘魅族Pro6的摄影实力,一探高清细节)

深入了解J2objc(探索J2objc工具的功能、优势和应用领域)

以牧马人鼠标玩CF,畅爽无限(操控精准,游戏体验倍增)

华强北手机质量如何?(探寻华强北手机的优劣势)

探索WoWDK的魅力(WoWDK职业特点揭秘,冰霜与鲜血共舞,征服暗黑世界!)

全面升级的新款iPad2017(性能卓越,功能升级,打造更高效的移动办公环境)

Sonyi5(揭秘Sonyi5的强大性能与创新科技)

友情链接

滇ICP备2023006006号-33