成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

是時候和else關鍵字說再見了……

開發 后端
沒有程序員不知道else關鍵字,If-else幾乎遍布于所有編程語言,這種簡單的條件邏輯使所有人都很容易理解。但優秀程序員的標志是,不使用這個關鍵字。

本文轉載自公眾號“讀芯術”(ID:AI_Discovery)

沒有程序員不知道else關鍵字,If-else幾乎遍布于所有編程語言,這種簡單的條件邏輯使所有人都很容易理解。

[[321176]]

但優秀程序員的標志是,不使用這個關鍵字。

筆者在開始編程的時候,最大錯誤之一是在編寫條件句時過度使用else關鍵字,早五年前筆者就告別else了。

原因何在呢?

想一下else是什么意思,其意為“如果滿足A就執行這個,如果不滿足A就執行那個”。

是時候和else關鍵字說再見了……

圖源:bevnet

如果A是二進制,就不存在問題——因為只存在兩種情況。

但是如果A是二進制變量的集合,或者包含著更大的變量,出現問題的機會就可能會出乎意料的大,且難以理解、測試和維護。

避免if/else if,只使用if語句,花時間確保if組的輸入條件是互斥的,這樣答案就不依賴于執行順序了。

  • 使用switch — case語句
  • 使用多態性處理復雜的條件情況,使代碼更像狀態模式。
  • 其保證了主要的執行通道,且有著更少的特殊情況。
  • 其迫使編程人員在每個函數開始時寫入處理數據所需的所有條件。

示例

例子是這樣的:一個信號燈(即信號燈對象)有著三種不同的狀態,紅色、黃色和綠色,每種狀態都有著其自己的一系列規則。規則如下:

  • 假設信號燈目前是紅色,則在一定延遲后,狀態由紅轉綠。
  • 然后在另一個延遲之后,狀態由綠轉黃。
  • 短暫延遲后,狀態由黃轉紅。
  • 不斷循環

不要使用if-else關鍵字

  1. constLightState= { 
  2.            GREEN: 0, 
  3.            YELLOW: 1, 
  4.            RED: 2 
  5.          } 
  6.                       varTrafficLight=function () { 
  7.                         var count =0  
  8.                         // default state = red 
  9.            var currentState =0
  10.                        this.change=function(state) { 
  11.              if (count++ >= 10 ) return 
  12.              currentState = state 
  13.              this.go(currentState) 
  14.            } 
  15.            this.go=function(state) { 
  16.              if (currentState ==LightState.GREEN) { 
  17.                console.log("Green -->for 1 minute") 
  18.                this.change(LightState.YELLOW) 
  19.              } 
  20.              elseif (currentState ==LightState.YELLOW) { 
  21.                console.log("Yellow -->for 10 seconds") 
  22.                this.change(LightState.RED) 
  23.              } elseif (currentState ==LightState.RED) { 
  24.                console.log("Red -->for 1 minute"); 
  25.                this.change(LightState.GREEN) 
  26.              } else { 
  27.                throwError("Invalid State") 
  28.              } 
  29.            } 
  30.            this.start=function() { 
  31.              this.change(LightState.GREEN) 
  32.            } 
  33.          } 

更簡單的方式

來看看不用else該怎么做:

  1. this.go=function (state) { 
  2.             if (currentState ==LightState.GREEN) { 
  3.               console.log("Green -->for 1 minute") 
  4.               this.change(LightState.YELLOW) 
  5.             } 
  6.             if (currentState ==LightState.YELLOW) { 
  7.               console.log("Yellow -->for 10 seconds") 
  8.               this.change(LightState.RED) 
  9.             } 
  10.             if (currentState ==LightState.RED) { 
  11.               console.log("Red -->for 1 minute"); 
  12.               this.change(LightState.GREEN) 
  13.             } 
  14.             if (currentState != LightState.GREEN&& currentState != LightState.RED&& currentState != LightState.YELLOW) { 
  15.               throwError("Invalid State") 
  16.             } 
  17.         } 

或者可以用一個switch代替,不得不合并不同的場景時,它看起來干凈得多,而if-else很快就會失控。

若干場景良好的情況下,switch 語句可能會比if-else語句更快。

  1. this.go=function (state) { 
  2.             if (currentState ==LightState.GREEN) { 
  3.               console.log("Green -->for 1 minute") 
  4.               this.change(LightState.YELLOW) 
  5.             } 
  6.             if (currentState ==LightState.YELLOW) { 
  7.               console.log("Yellow -->for 10 seconds") 
  8.               this.change(LightState.RED) 
  9.             } 
  10.             if (currentState ==LightState.RED) { 
  11.               console.log("Red -->for 1 minute"); 
  12.               this.change(LightState.GREEN) 
  13.             } 
  14.             if (currentState != LightState.GREEN&& currentState != LightState.RED&& currentState != LightState.YELLOW) { 
  15.               throwError("Invalid State") 
  16.             } 
  17.         } 

可以使用狀態模式刪除這些代碼中的所有if-else關鍵字

[[321178]]

圖源:unsplash

在這里,引入了許多if-else block/switch語句來保護各種條件,這個狀態模式適合這樣的場景。它允許對象根據當前的狀態有不同的行為,并且用戶可以定義狀態特定的行為。

在這種模式下,開始考慮信號燈的可能狀態,然后相應地隔離代碼。

  • 對于狀態特定的行為,需要有單獨的對象。
  • 信號燈中定義的操作將行為委托給當前狀態的對象。
  • 狀態本身觸發狀態轉換

信號燈:Green(1 minute) → Yellow (10 seconds)→ Red (1 minute)

  1. varTrafficLight=function () { 
  2.                              var count =0 
  3.                              // default state =green 
  4.                var currentState =newGreen(this);  
  5.                              this.change=function (state) { 
  6.                    // limits number of changes 
  7.                    if (count++ >= 10) return; 
  8.                    currentState = state
  9.                    currentState.go(); 
  10.                } 
  11.                this.start=function () { 
  12.                    currentState.go(); 
  13.                } 
  14.            }  
  15.                           varRed=function (light) { 
  16.                this.light= light 
  17.                              this.go=function () { 
  18.                    console.log(("Red -->for 1 minute")) 
  19.                    light.change(newGreen(light)); 
  20.                } 
  21.            }  
  22.                           varYellow=function (light) { 
  23.                this.light= light; 
  24.              
  25.                this.go=function () { 
  26.                    console.log("Yellow -->for 10 seconds") 
  27.                    light.change(newRed(light)); 
  28.                } 
  29.            }; 
  30.                              varGreen=function (light) { 
  31.                this.light= light; 
  32.              
  33.                this.go=function () { 
  34.                    console.log("Green -->for 1 minute"); 
  35.                    light.change(newYellow(light)); 
  36.                } 
  37.            }; 

輸出如下:

  1. Green → for 1 minute 
  2. Yellow → for 10 seconds 
  3. Red → for 1 minute 
  4. Green → for 1 minute 
  5. Yellow → for 10 seconds 
  6. Red → for 1 minute 
  7. Green → for 1 minute 
  8. Yellow → for 10 seconds 
  9. Red → for 1 minute 
  10. Green → for 1 minute 
  11. Yellow → for 10 seconds 

好代碼與糟糕代碼的區別在哪,你get到了嗎?

責任編輯:趙寧寧 來源: 讀芯術
相關推薦

2023-02-26 00:17:45

2020-07-13 20:26:30

手機64G手機APP

2025-02-19 08:27:56

2013-12-20 09:59:34

小米閃購模式雷軍

2021-07-21 07:11:21

TeamviewerWindowsMac

2024-11-08 14:00:29

關鍵字Animal編程

2019-10-10 10:30:26

MVCModelController

2013-03-19 11:28:01

Windows 7 R

2019-05-09 10:48:46

無人駕駛人工智能配送機器人

2013-08-13 14:22:33

開發者微軟Windows Pho

2021-01-12 09:22:18

Synchronize線程開發技術

2009-08-01 08:46:47

2014-07-14 11:47:03

火狐瀏覽器

2015-10-10 11:08:36

控制面板Windows 10微軟

2009-09-17 09:30:00

Linq LET關鍵字

2022-01-04 16:35:42

C++Protected關鍵字

2009-09-02 09:24:03

C# this關鍵字

2012-03-01 12:50:03

Java

2009-08-21 14:58:56

C# this關鍵字

2013-01-30 10:12:14

Pythonyield
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久精品这里精品 | 欧美中文字幕一区 | 一区二区三区在线免费看 | 久久久五月天 | 亚洲综合视频 | 在线观看的av | 国产精品一区在线 | 欧美在线 | 久久精品一区二 | 99国内精品 | 黄色电影在线免费观看 | 人人干在线| 在线免费国产 | 99久久国产综合精品麻豆 | 日本不卡免费新一二三区 | 免费观看www | 在线视频第一页 | 日本精品视频 | 亚洲a在线观看 | 日韩在线观看 | 国产在线中文字幕 | 国产精品网页 | 国产精品高潮呻吟久久 | 综合自拍 | 国产精品美女久久久av超清 | 亚洲国产精品va在线看黑人 | 日韩av在线免费 | 嫩呦国产一区二区三区av | 亚洲成人免费在线 | 亚洲第一视频 | 国产一区二区三区不卡av | 亚洲aⅴ | 一片毛片 | www国产亚洲精品久久网站 | 中文字幕欧美日韩一区 | 亚洲成人久久久 | 欧美日一区二区 | 国产原创视频 | 亚洲欧美日韩国产综合 | 久久综合久久综合久久 | 亚洲精品乱码久久久久久按摩观 |