亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

從 if else 到設計模式的轉變

2019-11-18 11:46:53
字體:
來源:轉載
供稿:網友

  面向過程設計和面向對象設計的主要區別是:是否在業務邏輯層使用冗長的if else判定。假如你還在大量使用if else,當然,界面表現層除外,即使你使用java/C#這樣完全面向對象的語言,也只能說明你的思維停留在傳統的面向過程語言上。

傳統思維習慣分析

  為什么會業務邏輯層使用if else,其實使用者的目的也是為了重用,但是這是面向過程編程的重用,程序員只看到代碼重用,因為他看到if else幾種情況下大部分代碼都是重復的,只有個別不同,因此使用if else可以避免重復代碼,并且認為這是模板Template模式。

  他范的錯誤是:程序員只從代碼運行順序這個方向來看待它的代碼,這種思維類似水管或串行電路,水沿著水管流動(代碼運行次序),當碰到幾個分管(子管),就分到這幾個分管子在流動,這里就相當于碰到代碼的if else處了。

  而使用OO,則首先打破這個代碼由上向下順序等同于運行時的先后循序這個規律,代碼結構不由執行循序決定,由什么決定呢?由OO設計;設計模式會取代這些if else,但是最后總是由一個Service等總類按照運行順序組裝這些OO模塊,只有一處,這處可包含事務,一般就是Service,EJB中是session bean。

  一旦需求變化,我們更多的可能是Service中各個OO模塊,甚至是只改動Service中的OO模塊執行順序就能符合需求。

  這里我們也看到OO分離的思路,將以前過程語言的一個Main函數徹底分解,將運行順序與代碼其他邏輯分離開來,而不是象面向過程那樣混亂在一起。所以有人感慨,OO也是要順序的,這是肯定的,要害是運行順序要單獨分離出來。

  是否有if else可以看出你有沒有將運行順序分離到家。

設計模式的切入口

  經常有人反映,設計模式是不錯,但是我很難用到,其實假如你使用if else來寫代碼時(除顯示控制以外),就是在寫業務邏輯,只不過使用簡單的判定語句來作為現實情況的替代者。

   還是以大家熟悉的論壇帖子為例子,如ForumMessage是一個模型,但是實際中帖子分兩種性質:主題貼(第一個根貼)和回帖(回以前帖子的帖子),這里有一個樸素的解決方案:
建立一個ForumMessage,然后在ForumMessage加入isTopic這樣判定語句,注重,你這里一個簡單屬性的判定引入,可能導致你的程序其他地方到處存在if else 的判定。

  假如我們改用另外一種分析實現思路,以對象化概念看待,實際中有主題貼和回帖,就是兩種對象,但是這兩種對象大部分是一致的,因此,我將ForumMessage設為表達主題貼;然后創建一個繼續ForumMessage的子類ForumMessageReply作為回帖,這樣,我在程序地方,如Service中,我已經確定這個Model是回帖了,我就直接下溯為ForumMessageReply即可,這個有點類似向Collection放入對象和取出時的強制類型轉換。通過這個手段我消滅了以后程序中if else的判定語句出現可能。

  從這里體現了,假如分析方向錯誤,也會導致誤用模式。

  討論設計模式舉例,不能沒有業務上下文場景的案例,否則無法決定是否該用模式,下面舉兩個對比的例子:

  第一. 這個帖子中舉例的第一個代碼案例是沒有上下文的,文中只說明有一段代碼:

main() {

if(case A){

//do with strategy A

}else(case B){

//do with strategy B

}else(case C){

//do with strategy C

}

}

 

  這段代碼只是純粹的代碼,沒有業務功能,所以,在這種情況下,我們就很難確定使用什么模式,就是一定用策略模式等,也逃不過還是使用if else的命運,設計模式不是魔法,不能將一段毫無意義的代碼變得簡單了,只能將其體現的業務功能更加輕易可拓展了。

  第二.在這個帖子中,作者舉了一個PacketParser業務案例,這段代碼是體現業務功能的,是一個數據包的分析,作者也比較了各種模式使用的不同,所以我們還是使用動態代理模式或Command模式來消滅那些可能存在的if else

  由以上兩個案例表明:業務邏輯是我們使用設計模式的切入點,而在分解業務邏輯時,我們習慣則可能使用if else來實現,當你有這種企圖或者已經實現代碼了,那么就應該考慮是否需要重構Refactoring了。

if else替代者

  那么實戰中,哪些設計模式可以替代if else呢?其實GoF設計模式都可以用來替代if else,我們分別描述如下:

  • 狀態模式 
      當數據對象存在各種可能性的狀態,而且這種狀態將會影響到不同業務結果時,那么我們就應該考慮是否使用狀態模式,當然,使用狀態模式之前,你必須首先有內存狀態這個概念,而不是數據庫概念,因為在傳統的面向過程的/面向數據庫的系統中,你很難發現狀態的,從數據庫中讀取某個值,然后根據這個值進行代碼運行分流,這是很多初學者常干的事情。參考文章:狀態對象:數據庫的替代者
      使用傳統語言思維的情況還有:使用一個類整數變量標識狀態:

     

    public class Order{

    PRivate int status;

    //說明:

    //status=1 表示訂貨但為查看 ;

    //status=2 表示已經查看未處理;

    //status=3 表示已經處理未付款

    //status=4 表示已經付款未發貨

    //status=5 表示已經發貨

    }


      上述類設計,無疑是將類作為傳統語言的函數來使用,這樣導致程序代碼中存在大量的if else。

  • 策略模式 
      當你面臨幾種算法或者公式選擇時,可以考慮策略模式,傳統過程語言情況是:從數據庫中讀取算法數值,數值1表示策略1,例如保存到數據庫;數值為2表示策略2,例如保存到xml文件中。這里使用if else作為策略選擇的開關。

  • command模式 
      傳統過程的思維情況是:假如客戶端發出代號是1或"A",那么我調用A.java這個對象來處理;假如代號是2或"B",我就調用B.java來處理,通過if else來判定客戶端發送過來的代碼,然后按事先約定的對應表,調用相應的類來處理。

  • MVC模式 
      MVC模式的傳統語言誤用和Command模式類似,在一個Action類中,使用if else進行前后臺調度,假如客戶端傳送什么命令;我就調用后臺什么結果;假如后臺處理什么結構,再決定推什么頁面,不過,現在我們使用Struts/JSF這樣MVC模式的框架實現者就不必范這種低級錯誤。

  • 職責鏈模式 
      職責鏈模式和Command模式是可選的,假如你實在不知道客戶端會發出什么代號;也沒有一個事先定義好的對照表,那么你只能編寫一個個類去碰運氣一樣打開這個包看一下就可以。與Command是不同在AOP vs Decorator一文中有分析。

  • 代理或動態代理模式 
      代理對象可以是符合某種條件的代表者,比如,權限檢驗,傳統面向過程思維是:當一個用戶登陸后,訪問某資源時,使用if else進行判定,只有某種條件符合時,才能答應訪問,這樣權限判定和業務數據邏輯混亂在一起,使用代理模式可以清楚分離,假如嫌不太好,使用動態代理,或者下面AOP等方式。

  • AOP或Decorator模式
      
      其實使用filter過濾器也可以替代我們業務中的if else,過濾器起到一種過濾和篩選作用,將符合本過濾器條件的對象攔截下來做某件事情,這就是一個過濾器的功能,多個過濾器組合在一起實際就是if else的組合。
      所以,假如你實在想不出什么辦法,可以使用過濾器,將過濾器看成防火墻就比較好理解,當客戶端有一個請求時,經過不同性質的防火墻,這個防火墻是攔截端口的;那個防火墻是安全檢查攔截等等。過濾器也如同紅藍白各種光濾鏡;紅色濾鏡只能將通過光線中的紅色攔截了;藍色濾鏡將光線中的藍色攔截下來,這實際上是對光線使用if else進行分解。

    從 if else 到設計模式的轉變
      如圖,通過一個個條件過濾器我們立體地實現了對信號的分離,假如你使用if else,說明你是將圖中的條件1/2/3/4合并在一起,在同一個地方實現條件判定。
      需要深入了解過濾器的實現細節和微小區別,請參考文章:AOP vs Decorator



  • 發表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發表
    亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
    国产精品电影在线观看| 日韩激情视频在线播放| 日韩精品一区二区三区第95| 福利二区91精品bt7086| 欧美黑人视频一区| 日韩免费av在线| 国内精品在线一区| 最近2019中文字幕一页二页| 狠狠做深爱婷婷久久综合一区| 日韩av在线不卡| 亚洲精品98久久久久久中文字幕| 搡老女人一区二区三区视频tv| 九九综合九九综合| 成年人精品视频| 日韩中文字幕精品| 欧美国产极速在线| 国产精品91久久| 欧美日韩国产91| 欧美日本在线视频中文字字幕| 欧美精品成人91久久久久久久| 亚洲影院色无极综合| 日本在线观看天堂男亚洲| 亚洲精品国产欧美| 日韩大胆人体377p| 日韩在线观看网站| 久久成人一区二区| 国产精品美女在线观看| 精品国产户外野外| 国产精品视频在线播放| 国产视频在线观看一区二区| 九九热精品在线| 久久99视频免费| 亚洲成人久久网| 午夜精品99久久免费| 亚洲性无码av在线| 亚洲成人精品视频在线观看| 日韩美女毛茸茸| 91免费看国产| 久久精品人人爽| 亚洲精品日韩丝袜精品| 亚洲专区在线视频| 日本高清久久天堂| 国产在线拍偷自揄拍精品| 久久久久999| 欧美激情亚洲另类| 亚洲国产精品小视频| 欧美俄罗斯乱妇| 久久精品国产欧美亚洲人人爽| 欧美电影免费播放| 欧美日韩国产成人| 日本精品视频在线| 中文字幕不卡在线视频极品| 91免费版网站入口| 色伦专区97中文字幕| 亚洲国产成人在线播放| 欧美孕妇孕交黑巨大网站| 日韩精品在线视频美女| 国产精品日韩专区| 青青草精品毛片| 国产噜噜噜噜噜久久久久久久久| 亚洲人成网站999久久久综合| 欧美精品videosex牲欧美| 欧美精品激情在线观看| 在线播放国产精品| 国内精品久久久久久久久| 欧美日韩国产精品专区| 日韩欧美在线视频免费观看| 91免费版网站入口| 日韩精品视频在线播放| 日韩欧美极品在线观看| 日韩一二三在线视频播| 日韩资源在线观看| 亚洲国产黄色片| 97精品久久久中文字幕免费| 欧洲中文字幕国产精品| 国产自产女人91一区在线观看| 欧美最近摘花xxxx摘花| 久久精品一偷一偷国产| 欧美在线一级视频| 中文字幕亚洲天堂| 欧美亚洲视频在线看网址| 69av视频在线播放| 97avcom| 亚洲老头同性xxxxx| 亚洲精品自拍第一页| 日韩一区二区三区在线播放| 91精品国产自产在线老师啪| 91九色综合久久| 久久人人爽人人爽人人片亚洲| 亚洲国产美女久久久久| 亚洲人成人99网站| 国产精品网站视频| 国产成人精品av| 欧美激情一区二区久久久| 精品国产网站地址| 久久久久久999| 国产视频精品一区二区三区| 日韩在线播放视频| 国产精品久久久久久超碰| 国产午夜精品一区理论片飘花| 亚洲成人久久一区| 日韩一区二区精品视频| 北条麻妃一区二区三区中文字幕| 中文字幕在线精品| 欧美激情网站在线观看| 国产欧美一区二区三区久久人妖| 国产主播精品在线| 国产精品九九久久久久久久| 欧美激情第99页| 国产精选久久久久久| 91精品视频免费看| 国产一区二区欧美日韩| 亚洲福利视频免费观看| 国产亚洲人成a一在线v站| 欧美视频在线观看 亚洲欧| 国产精品露脸自拍| 久久国产精彩视频| 国产一区二区三区毛片| 国产精品劲爆视频| 色爱av美腿丝袜综合粉嫩av| 亚洲韩国日本中文字幕| 日韩中文字在线| 国产日韩综合一区二区性色av| 国产精品视频永久免费播放| 高清视频欧美一级| 久久99热精品这里久久精品| 亚洲一区亚洲二区| 91欧美精品午夜性色福利在线| 91丝袜美腿美女视频网站| 日本久久精品视频| 亚洲精品www| 国产一区玩具在线观看| 亚洲精品久久久一区二区三区| 日韩av在线免播放器| 亚洲午夜久久久影院| 91精品视频在线播放| 一本色道久久综合狠狠躁篇怎么玩| 国产精品三级在线| 插插插亚洲综合网| 久久久免费电影| 国产精品96久久久久久| 中文字幕亚洲一区二区三区五十路| 欧美日韩中文字幕在线| 在线观看欧美成人| 亚洲国产成人精品电影| 欧美中文字幕在线视频| 欧美视频不卡中文| 国产成人精品国内自产拍免费看| 成人网欧美在线视频| 久久久亚洲网站| 色噜噜狠狠狠综合曰曰曰88av| 亚洲欧美日韩爽爽影院| 欧美另类第一页| 538国产精品一区二区免费视频| 色综合久综合久久综合久鬼88| 亚洲欧美综合另类中字| 午夜精品视频在线| 成人黄色免费在线观看| 欧美在线视频网| 欧美日韩国产页| 欧美视频专区一二在线观看| 欧美国产日韩一区| 91中文精品字幕在线视频| 国产99视频在线观看|