1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        CTO 寫的代碼,真是絕了

        共 3418字,需瀏覽 7分鐘

         ·

        2020-08-22 04:23

        點擊上方“碼農(nóng)突圍”,馬上關(guān)注
        這里是碼農(nóng)充電第一站,回復(fù)“666”,獲取一份專屬大禮包
        真愛,請設(shè)置“星標(biāo)”或點個“在看”
        作者:聚IT
        來源:touyatoutiao.com/i6847406631983153672

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

        解決思路


        1、首先構(gòu)建一個 GeneralChannelRule 基礎(chǔ)規(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ù)進(jìn)行處理。

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

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

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

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

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

        新的思路


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

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

        最后


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

        ---END---
        重磅!碼農(nóng)突圍-技術(shù)交流群已成立

        掃碼可添加碼農(nóng)突圍助手,可申請加入碼農(nóng)突圍大群和細(xì)分方向群,細(xì)分方向已涵蓋:Java、Python、機器學(xué)習(xí)、大數(shù)據(jù)、人工智能等群。
        一定要備注:開發(fā)方向+地點+學(xué)校/公司+昵稱(如Java開發(fā)+上海+拼夕夕+猴子),根據(jù)格式備注,可更快被通過且邀請進(jìn)群

        ▲長按加群

        推薦閱讀

        ? ?華為、阿里員工跳槽至微軟遭抵制?GitHub上996項目瘋狂被漲星到20.1K,網(wǎng)友炸鍋了
        ???你還在認(rèn)為 count(1) 比 count(*) 效率高?
        ???公司用了 6 年的分布式鎖,很是牛逼?。?/a>
        ???最硬核畢業(yè)證:帶著自己設(shè)計的芯片畢業(yè),國科大 16 級本科生交付「一生一芯」首期成果
        ?? 不要再自己封裝各種Util工具類了,這款神仙級框架你值得擁有!
        ?? 最年輕36歲!2020年度國家“杰出青年”名單公布,21人在計算機領(lǐng)域貢獻(xiàn)突出

        最近面試BAT,整理一份面試資料Java面試BAT通關(guān)手冊,覆蓋了Java核心技術(shù)、JVM、Java并發(fā)、SSM、微服務(wù)、數(shù)據(jù)庫、數(shù)據(jù)結(jié)構(gòu)等等。

        獲取方式:點“在看”,關(guān)注公眾號并回復(fù)?BAT?領(lǐng)取,更多內(nèi)容陸續(xù)奉上。

        如有收獲,點個在看,誠摯感謝明天見(??ω??)??

        瀏覽 33
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

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

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            激情中文网 | 国产51精品入口豆花 | 亚洲日本看视频 | 欧美操逼电影 | 亚洲精品成人app | 亚洲视频999 | 国产成人亚洲精品无码古代 | 日韩三级电影一区 | 91精品中文字幕 | 秋霞影院一区二区三区 |