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

干掉if-else,多點套路,少點彎路!

運維 數(shù)據(jù)庫運維 開發(fā)工具
它可能是也是你日常默認的編碼模式。但是,讓我們從今天起結束這種方法,用狀態(tài)對象代替 If-else。

 你也許已經(jīng)看了無數(shù)使用 if-else 語句的教程,你可能也讀過不少使用 if-else 作為事實上的分支技術的編程書籍。

[[347735]] 

圖片來自 Pexels

它可能是也是你日常默認的編碼模式。但是,讓我們從今天起結束這種方法,用狀態(tài)對象代替 If-else。

請注意,如果你正在編寫的代碼需要根據(jù)當前狀態(tài)改變其實現(xiàn)的類,你需要改用這種方法。如果你的代碼不是處理對象的狀態(tài)變化,你需要選擇其他方法。

即使你已經(jīng)聽說過狀態(tài)模式,你可能也想了解如何在生產(chǎn)代碼中實現(xiàn)。

對于以前了解不多的人,下面有一段非常簡單的介紹。

對 if-else 增加任何新的條件,都會增加復雜性。應用狀態(tài)模式(state pattern),你只需使用專門的狀態(tài)對象,代替 if-else 語句來改變一個對象的行為。

像下面這樣代碼的日子,已經(jīng)一去不復返了:

 

警告:PTSD 觸發(fā)器。另外,希望你能發(fā)現(xiàn)里面的邏輯錯誤(除了代碼整體一團糟)。

你以前肯定寫過更復雜的分支。我?guī)啄昵按_實寫過。

上面的分支邏輯雖然不是很復雜,但如果再添加新的條件,這個邏輯會更加混亂。

另外,如果你認為創(chuàng)建新的類,而不是簡單地使用分支語句聽起來很煩人,那就可以繼續(xù)看下面的實際代碼,它簡潔而優(yōu)雅。

更妙的是,它會讓你的代碼庫變得更 SOLID,除了 "D" 部分。

"好了,我相信 if-else 是邪惡的,現(xiàn)在請告訴我如何避免混亂的分支代碼"!

我們將看看我是如何在生產(chǎn)代碼中替換 if-else 分支的。這是一個假想的例子,但方法和我在大型客戶的代碼庫中使用的是一樣的。

讓我們創(chuàng)建一個非常簡單的 Booking 類,它有幾個狀態(tài)。它也會有兩個公共方法:Accept() 和 Cancel()。

我畫了一個圖,顯示了一個預訂可能處于的不同狀態(tài):

 

將分支邏輯從代碼中重構出來,可以分為三步:

  • 創(chuàng)建一個抽象的基本狀態(tài)類。
  • 將每個狀態(tài)作為一個獨立的類來實現(xiàn),繼承于基本狀態(tài)。
  • 讓 Booking 類有一個私有的或內部的方法,把狀態(tài)基類作為參數(shù)。

演示時間

首先,我們需要一個用于繼承所有狀態(tài)的基礎狀態(tài)類。

 

請注意這個基類也有 Accept 和 Cancel 這兩個方法,雖然這里它們被標記為內部方法。

此外,基礎狀態(tài)有一個特殊的 EnterState(Booking booking)方法。每當一個新的狀態(tài)被分配給預訂對象時,這個方法就會被調用。

其次,我們要為我們要表示的每一個狀態(tài)單獨做一個類。

請注意每個類是如何代表一個狀態(tài)的,就像上圖描述的那樣。另外,CancelledState 不會不允許預訂再轉換到一個新的狀態(tài)。這個類的設計與 Null Object Pattern 非常相似。 

最后,再看看 Booking 類本身: 

看到 Booking 類是如何簡單地將 Accept 和 Cancel 的實現(xiàn)委托給它的狀態(tài)對象的嗎? 

這樣做可以讓我們去掉很多條件邏輯,讓每個狀態(tài)只關注對自己重要的東西 -- 當前狀態(tài),以及也有可能將預訂轉換到新的狀態(tài)。

如何處理新的條件功能?

如果新功能通常會使用一些條件檢查來實現(xiàn),現(xiàn)在你可以直接創(chuàng)建一個新的狀態(tài)類。

就這么簡單。你將不再需要處理笨重的 if-else 語句。

如何將狀態(tài)對象持久化在數(shù)據(jù)庫中?

不需要。

當把一個對象保存到 SQL 或 NoSQL 數(shù)據(jù)庫時,狀態(tài)對象并不重要。只有知道對象的狀態(tài),以及如何將其映射到列才是重要的。

你可以將狀態(tài)映射到一個友好的類型名、一個枚舉或一個整型。只要你有某種方法將保存的值轉換回狀態(tài)對象,那就任何方法都行。

但為什么你還在使用 if?

是的,if 有時是必不可少的,尤其是作為防護語句(guard clause)使用時。if-else 組合才是讓人頭疼的可維護性的根本原因。

但是文中介紹的方法會帶來很多額外的類?

的確如此。正如我在另一篇文章中提到的,復雜性并不源于你擁有的類的數(shù)量,而是源于這些類所承擔的責任。

擁有許多專門的類,會讓你的代碼庫更易讀、更易維護,而且整體上更容易讓人喜歡。

作者:Nicklas Millard

編輯:陶家龍

出處:轉載自公眾號高可用架構(ID:ArchNotes)

 

責任編輯:武曉燕 來源: 高可用架構
相關推薦

2025-06-26 01:10:00

服務定位解析器Spring

2020-04-09 08:29:50

編程語言事件驅動

2021-01-29 07:45:27

if-else代碼數(shù)據(jù)

2023-06-02 07:30:24

If-else結構流程控制

2021-04-20 08:02:08

業(yè)務數(shù)據(jù)用戶

2013-03-06 10:28:57

ifJava

2022-01-13 10:45:59

if-else代碼Java

2021-04-13 06:39:13

代碼重構code

2022-07-11 08:16:55

策略模式if-else

2021-03-10 07:20:43

if-else靜態(tài)代碼

2018-12-04 12:52:32

攜號轉網(wǎng)手機號碼消費者

2020-12-15 09:31:58

CTOif-else代碼

2020-05-13 14:15:25

if-else代碼前端

2021-11-04 08:53:00

if-else代碼Java

2025-04-24 08:40:00

JavaScript代碼return語句

2020-07-09 08:59:52

if else模板Service

2025-04-21 00:00:05

2024-06-18 18:36:03

2020-09-27 14:24:58

if-else cod業(yè)務

2020-04-20 15:40:03

if-elseJava優(yōu)化
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲成人免费 | 久久33 | 激情综合五月天 | 欧美日韩国产一区二区三区 | 日韩精品免费播放 | 中文字幕一区二区三区四区 | 国产精品国产成人国产三级 | 欧美999| 国产精品视频专区 | 亚洲综合久久精品 | 日本在线网址 | 黄色av免费网站 | 欧美精品1区2区3区 免费黄篇 | 91极品视频| 电影91久久久| chinese中国真实乱对白 | 亚洲综合大片69999 | 伦理片97 | 国产小视频在线 | 日韩靠逼 | 国产一区二区三区在线 | 91原创视频 | 国产精品国产三级国产aⅴ中文 | 午夜视频免费在线观看 | 久久精品国产99国产 | 国产日韩av一区二区 | 一区二区三区在线免费观看 | 亚洲三区在线 | 日日做夜夜爽毛片麻豆 | 99re视频| 天堂久久久久久久 | 国产超碰人人爽人人做人人爱 | 精品美女久久久 | 欧美一区二区三区在线播放 | 国产一区二区激情视频 | 日韩一级 | av毛片 | 欧美不卡一区二区三区 | 久久精品中文字幕 | 午夜影院在线 | 精品国产一区二区三区久久狼黑人 |