<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>

          老大寫的代碼,真是絕了!

          共 3056字,需瀏覽 7分鐘

           ·

          2020-09-02 00:04

          作者:聚IT

          來源:touyatoutiao.com/i6847406631983153672


          場景:當(dāng)我們接收到一些數(shù)據(jù)需要對其進(jìn)行處理時,由于它們來自于不同的渠道(如:騰訊,頭條),不同渠道所需的處理方式不同,下面我們寫一個簡單Demo來實(shí)現(xiàn)該的場景。(ps:這篇之前發(fā)過,不過代碼格式有點(diǎn)問題,今天重新發(fā)一次)

          解決思路


          1、首先構(gòu)建一個 GeneralChannelRule 基礎(chǔ)規(guī)則抽象類,定義一個抽象方法process(),不同的渠道都需要實(shí)現(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ù)進(jìn)行處理。


          public?static?void?main(String[] args) {
          ????????//這里我們模擬接收到的數(shù)據(jù),其渠道為為TOUTIAO,來自頭條的數(shù)據(jù)
          ????????String sign = "TOUTIAO";
          ????????GeneralChannelRule rule;
          ????????//根據(jù)對應(yīng)渠道獲取對應(yīng)的具體規(guī)則實(shí)現(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();
          ????}



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

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

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

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

          新的思路


          1、下面我們調(diào)整一下枚舉類,增加一個GeneralChannelRule屬性,并且給對應(yīng)渠道構(gòu)建對應(yīng)的GeneralChannelRule實(shí)現(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ī)則具體實(shí)現(xiàn)進(jìn)行綁定。通過改變:


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


          最后


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


          -End-


          長按進(jìn)入小程序,進(jìn)行30天打卡

          打卡第13期,20本新書,快來看看!


          (更多精彩值得期待……)


          最近熱文:


          一周內(nèi)B站瘋轉(zhuǎn)5.6W次,好東西呀!
          TikTok軟件,請務(wù)必謹(jǐn)慎使用!
          美國如果把根域名服務(wù)器封了,中國會從網(wǎng)絡(luò)上消失?
          超全遞歸技巧整理,這次一起拿下遞歸
          LeetCode1-20題匯總,速度收藏!
          限時加入!程序員讀者微信群,先到先得!


          關(guān)注下面公眾號,查看更多Java文章

          瀏覽 71
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點(diǎn)贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          <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>
                  亚洲精品官网 | 变态别类一区二区 | 国产亚洲精品久久久久动 | 丁香激情综合网 | 色婷婷五月天导航 |