<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          CTO 寫的代碼,真是絕了!

          共 3264字,需瀏覽 7分鐘

           ·

          2021-02-20 11:20


          點擊上方?藍字?關注我們!



          Java,Python,C/C++,Linux,PHP,Go,C#,QT,大數(shù)據(jù),算法,軟件教程,前端,簡歷,畢業(yè)設計等分類,資源在不斷更新中... 點擊領取

          每天 11 點更新文章,餓了點外賣,點擊 ??《無門檻外賣優(yōu)惠券,每天免費領!》


          • 解決思路
          • 新的思路
          • 最后

          場景:當我們接收到一些數(shù)據(jù)需要對其進行處理時,由于它們來自于不同的渠道(如:騰訊,頭條),不同渠道所需的處理方式不同,下面我們寫一個簡單Demo來實現(xiàn)該的場景。

          解決思路

          1、首先構建一個 GeneralChannelRule 基礎規(guī)則抽象類,定義一個抽象方法process(),不同的渠道都需要實現(xiàn)該抽象方法。

          public?abstract?class?GeneralChannelRule?{
          ?public?abstract?void?process();
          }

          2、編寫一個騰訊的規(guī)則類,定義具體對于騰訊渠道數(shù)據(jù)的處理邏輯

          public?class?TencentChannelRule?extends?GeneralChannelRule
          ???@Override
          ????public?void?process()?
          {
          ????????//?Tencent處理邏輯
          ????}
          }

          3、編寫一個頭條的規(guī)則類,定義具體對于頭條數(shù)據(jù)的處理邏輯

          public?class?TouTiaoChannelRule?extends?GeneralChannelRule
          ???@Override
          ????public?void?process()?
          {
          ????????//?TouTiao處理邏輯
          ????}
          }

          4、建立一個簡單的枚舉類

          public?enum?ChannelRuleEnum?{
          ????/**
          ?????*?頭條
          ?????*/

          ????TOUTIAO("TOUTIAO"),
          ????/**
          ?????*?騰訊
          ?????*/

          ????TENCENT("TENCENT"),
          ????;
          ??....
          }

          5、使用規(guī)則對數(shù)據(jù)進行處理。

          public?static?void?main(String[]?args)?{
          ????????//這里我們模擬接收到的數(shù)據(jù),其渠道為為TOUTIAO,來自頭條的數(shù)據(jù)
          ????????String?sign?=?"TOUTIAO";
          ????????GeneralChannelRule?rule;
          ????????//根據(jù)對應渠道獲取對應的具體規(guī)則實現(xiàn)類
          ????????if?(ChannelRuleEnum.TENCENT.code.equals(sign))?{
          ????????????rule?=?new?TencentChannelRule();
          ????????}?else?if?(ChannelRuleEnum.TOUTIAO.code.equals(sign))?{
          ????????????rule?=?new?TouTiaoChannelRule();
          ????????}?else?{
          ????????????//匹配不到
          ????????}
          ????????//執(zhí)行
          ????????rule.process();
          ????}

          解析:如果通過上面的方式,則存在則兩個缺點。

          當我們需要新增新的渠道的時候,需要對main方法中的邏輯進行修改調(diào)整。這違背了設計模式中的開放封閉規(guī)則。開放封閉原bai則的核心的思想是軟件實體是可擴du展,而不可zhi修改的。

          也就是說,對擴展是開dao放的,而對修改是封閉的

          新增渠道后,修改代碼會產(chǎn)生大量的if else,不太優(yōu)雅。為了解決以上的兩個問題,我們可以借助枚舉類來巧妙優(yōu)化。

          新的思路

          1、下面我們調(diào)整一下枚舉類,增加一個GeneralChannelRule屬性,并且給對應渠道構建對應的GeneralChannelRule實現(xiàn)類,新增一個match() 匹配方法。

          public?enum?ChannelRuleEnum?{

          ????/**
          ?????*?頭條
          ?????*/

          ????TOUTIAO("TOUTIAO",new?TouTiaoChannelRule()),
          ????/**
          ?????*?騰訊
          ?????*/

          ????TENCENT("TENCENT",new?TencentChannelRule()),
          ????;

          ????public?String?name;

          ????public?GeneralChannelRule?channel;

          ????ChannelRuleEnum(String?name,?GeneralChannelRule?channel)?{
          ????????this.name?=?name;
          ????????this.channel?=?channel;
          ????}

          ??//匹配
          ????public?static?ChannelRuleEnum?match(String?name){
          ????????ChannelRuleEnum[]?values?=?ChannelRuleEnum.values();
          ????????for?(ChannelRuleEnum?value?:?values)?{
          ????????????if(value.name.equals(name)){
          ????????????????return?value;
          ????????????}
          ????????}
          ????????return?null;
          ????}
          ????public?String?getName()?{
          ????????return?name;
          ????}

          ????public?GeneralChannelRule?getChannel()?{
          ????????return?channel;
          ????}
          }

          2、改寫程序

          public?static?void?main(String[]?args)?{
          ????????String?sign?=?"TOUTIAO";
          ????????ChannelRuleEnum?channelRule?=?ChannelRuleEnum.match(sign);
          ????????GeneralChannelRule?rule?=?channelRule.channel;
          ????????rule.process(sign);
          ????}

          解析:通過使用枚舉類,在枚舉中將 key 與 規(guī)則具體實現(xiàn)進行綁定。通過改變:

          可以減少if -else使得代碼更加優(yōu)雅 如果需要新增渠道,我們只需要在編寫具體規(guī)則實現(xiàn)類并繼承GeneralChannelRule抽象類,并在枚舉類中新增的枚舉,而不需要改動到原先的任何代碼。這符合了開發(fā)封閉原則。

          最后

          以上是通過枚舉來巧妙干掉if-else的方案,對于減少 if-else 還有很多有趣的解決方案(如:狀態(tài)設計模式等),感興趣的朋友去查閱相關的資料。


          往期推薦

          一個員工的離職成本到底有多恐怖!

          美團面試官:訂單自動關閉的功能該如何實現(xiàn)?

          記一次線上Redis高負載排查經(jīng)歷

          這簡歷一看就是包裝過的


          看完文章,餓了點外賣,點擊 ??《無門檻外賣優(yōu)惠券,每天免費領!》

          END



          若覺得文章對你有幫助,隨手轉(zhuǎn)發(fā)分享,也是我們繼續(xù)更新的動力。


          長按二維碼,掃掃關注哦

          ?「C語言中文網(wǎng)」官方公眾號,關注手機閱讀教程??


          必備編程學習資料


          目前收集的資料包括:?Java,Python,C/C++,Linux,PHP,go,C#,QT,git/svn,人工智能,大數(shù)據(jù),單片機,算法,小程序,易語言,安卓,ios,PPT,軟件教程,前端,軟件測試,簡歷,畢業(yè)設計,公開課?等分類,資源在不斷更新中...


          點擊“閱讀原文”,立即免費領取最新資料!
          ??????
          瀏覽 115
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  韩国免费一区二区三区 | 成人做爰黄 片免费观看 | 日韩精品人妻 | 91嫩草欧美久久久九九九 | 大香蕉黄色电影 |