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

公司主营业务:成都网站制作、网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联公司推出齐齐哈尔免费做网站回馈大家。
没有程序员不知道else关键字,If-else几乎遍布于所有编程语言,这种简单的条件逻辑使所有人都很容易理解。
但优秀程序员的标志是,不使用这个关键字。
笔者在开始编程的时候,最大错误之一是在编写条件句时过度使用else关键字,早五年前笔者就告别else了。
原因何在呢?
想一下else是什么意思,其意为“如果满足A就执行这个,如果不满足A就执行那个”。
图源:bevnet
如果A是二进制,就不存在问题——因为只存在两种情况。
但是如果A是二进制变量的集合,或者包含着更大的变量,出现问题的机会就可能会出乎意料的大,且难以理解、测试和维护。
避免if/else if,只使用if语句,花时间确保if组的输入条件是互斥的,这样答案就不依赖于执行顺序了。
示例
例子是这样的:一个信号灯(即信号灯对象)有着三种不同的状态,红色、黄色和绿色,每种状态都有着其自己的一系列规则。规则如下:
不要使用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到了吗?
                文章标题:是时候和else关键字说再见了……
                
                本文网址:http://www.csdahua.cn/qtweb/news35/175835.html
            
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网