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

          枚舉很好用??!為啥阿里不建議返回值用枚舉??

          共 1753字,需瀏覽 4分鐘

           ·

          2021-11-14 01:03

          相關(guān)閱讀

          300本計(jì)算機(jī)編程的經(jīng)典書籍下載

          AI全套:Python3+TensorFlow打造人臉識(shí)別智能小程序

          最新人工智能資料-Google工程師親授 Tensorflow-入門到進(jìn)階

          Java架構(gòu)全階段七期完整

          黑馬頭條項(xiàng)目 - Java Springboot2.0(視頻、資料、代碼和講義)14天完整版

          Spring核心編程思想


          來自:zhihu.com/question/52760637

          提問

          小伙伴說在一次接口定義時(shí),使用了枚舉,結(jié)果被其它人深深嫌棄,說不好拓展。
          為什么會(huì)被嫌棄呢?我們先來看看阿里開發(fā)手冊關(guān)于枚舉使用的建議
          從手冊可以看出,定義和使用枚舉,阿里開發(fā)手冊都是支持的,但是為啥,返回值就要反對了呢?

          看看作者孤盡是怎么說的

          由于升級(jí)原因,導(dǎo)致雙方的枚舉類不盡相同,在接口解析,類反序列化時(shí)出現(xiàn)異常。Java中出現(xiàn)的任何元素,在Gosling的角度都會(huì)有背后的思考和邏輯(盡管并非絕對完美,但Java的頂層抽象已經(jīng)是天才級(jí)了),比如:接口、抽象類、注解、和本文提到的枚舉。
          枚舉有好處,類型安全,清晰直接,還可以使用等號(hào)來判斷,也可以用在switch中。
          它的劣勢也是明顯的,就是不能擴(kuò)展??墒菫槭裁丛诜祷刂岛蛥?shù)進(jìn)行了區(qū)分呢,如果不兼容,那么兩個(gè)都有問題,怎么允許參數(shù)可以有枚舉。當(dāng)時(shí)的考慮,如果參數(shù)也不能用,那么枚舉幾乎無用武之地了。
          參數(shù)輸出,畢竟是本地決定的,你本地有的,傳送過去,向前兼容是不會(huì)有問題的。搜索公眾號(hào)互聯(lián)網(wǎng)架構(gòu)師后臺(tái)回復(fù)“2T”,獲取一份驚喜禮包。
          但如果是接口返回,就比較惡心了,因?yàn)榻馕龌貋淼倪@個(gè)枚舉值,可能本地還沒有,這時(shí)就會(huì)拋出序列化異常。
          比如:你的本地枚舉類,有一個(gè)天氣 Enum:SUNNY, RAINY, CLOUDY,如果根據(jù)天氣計(jì)算心情的方法:guess(WeatcherEnum xx),傳入這三個(gè)值都是可以的。
          返回值:Weather guess(參數(shù)),那么對方運(yùn)算后,返回一個(gè)SNOWY,本地枚舉里沒有這個(gè)值,傻眼了。

          不過,另一位網(wǎng)友Brian的回答也很通俗易懂

          枚舉,就是把已知的全部羅列出來。作為二方/三方庫的提供者,我支持什么,你們就是用什么,這樣是安全的。
          庫版本升級(jí)后我支持了更多,你不知道情況下自然不會(huì)使用,反正我不支持的參數(shù)你不可能傳遞給我,所以作為輸入,枚舉簡直就是安全保障。
          但作為返回值,情況就反過來了。
          我先告訴你這些這些可以有,然后你規(guī)定這些這些可以有,除此之外都沒有。但是,是我說了算而不是你,所以你的規(guī)定狗屁不是。
          沒有仔細(xì)看手冊(假設(shè)有的話)的每一個(gè)字,鬼知道升級(jí)后的api會(huì)返回什么,拋異常的可能性直趨百分百。

          全棧架構(gòu)社區(qū)交流群

          ?「全棧架構(gòu)社區(qū)」建立了讀者架構(gòu)師交流群,大家可以添加小編微信進(jìn)行加群。歡迎有想法、樂于分享的朋友們一起交流學(xué)習(xí)。

          掃描添加好友邀你進(jìn)架構(gòu)師群,加我時(shí)注明姓名+公司+職位】

          看完本文有收獲?請轉(zhuǎn)發(fā)分享給更多人


          往期資源:


          Flutter 移動(dòng)應(yīng)用開發(fā)實(shí)戰(zhàn) 視頻(開發(fā)你自己的抖音APP)
          Java面試進(jìn)階訓(xùn)練營 第2季(分布式篇)
          Java高級(jí) - 分布式系統(tǒng)開發(fā)技術(shù)視頻


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

          手機(jī)掃一掃分享

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

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <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在线视频 | 成人菠萝视频 | 大香蕉插插插 | XA片一级日本 | 亚洲精品一区二区三区2023年最新 |