elastic-job 源碼解讀之從源碼看null值

? 在elastic-Job作業(yè)啟動的時候文留,首先會去持久化LiteJob的配置信息,持久化保存之前先去會檢查job存不存在竭沫,讀取zk上的原有配置的job信息燥翅,如果節(jié)點不存在,或者需要重寫的時候蜕提,去注冊中心寫節(jié)點或者是修改節(jié)點數據森书。

    //SchedulerFacade.java 
    /**
     * 更新作業(yè)配置.
     *
     * @param liteJobConfig 作業(yè)配置
     * @return 更新后的作業(yè)配置
     */
  public LiteJobConfiguration updateJobConfiguration(final LiteJobConfiguration liteJobConfig) {
    //持久化LiteJob配置
    configService.persist(liteJobConfig);
    return configService.load(false);
  }

    //ConfigurationService.java
     /**
     * 持久化分布式作業(yè)配置信息.
     *
     * @param liteJobConfig 作業(yè)配置
     */
    public void persist(final LiteJobConfiguration liteJobConfig) {
        //檢查沖突作業(yè)
        checkConflictJob(liteJobConfig);
        if (!jobNodeStorage.isJobNodeExisted(ConfigurationNode.ROOT) || liteJobConfig.isOverwrite()) {
            jobNodeStorage.replaceJobNode(ConfigurationNode.ROOT, LiteJobConfigurationGsonFactory.toJson(liteJobConfig));
        }
    }

  //檢查沖突作業(yè)
 private void checkConflictJob(final LiteJobConfiguration liteJobConfig) {
        //查從注冊中心獲取舊的配置
        Optional<LiteJobConfiguration> liteJobConfigFromZk = find();
        //返回Optional是啥這個Optional是啥?谎势?.isPresent是啥方法凛膏,百思不得其解
        if (liteJobConfigFromZk.isPresent() && !liteJobConfigFromZk.get().getTypeConfig().getJobClass().equals(liteJobConfig.getTypeConfig().getJobClass())) {
            throw new JobConfigurationException("Job conflict with register center. The job '%s' in register center's class is '%s', your job class is '%s'", 
                    liteJobConfig.getJobName(), liteJobConfigFromZk.get().getTypeConfig().getJobClass(), liteJobConfig.getTypeConfig().getJobClass());
        }
    }
    //返回值是optional,這個是什么東東脏榆?猖毫?
    private Optional<LiteJobConfiguration> find() {
        if (!jobNodeStorage.isJobNodeExisted(ConfigurationNode.ROOT)) {
            return Optional.absent();
        }
        LiteJobConfiguration result = LiteJobConfigurationGsonFactory.fromJson(jobNodeStorage.getJobNodeDataDirectly(ConfigurationNode.ROOT));
        if (null == result) {
            // TODO 應該刪除整個job node,并非僅僅刪除config node
            jobNodeStorage.removeJobNodeIfExisted(ConfigurationNode.ROOT);
        }
        //這里還是一臉懵逼 optional是干嘛的?须喂?
        return Optional.fromNullable(result);
    }
    

? 根據邏輯吁断,應該是在配置中心獲取舊的配置,檢查舊配置是否存在坞生,判斷是不是null仔役,然后再判斷要不要重寫, Optional<LiteJobConfiguration> liteJobConfigFromZk = find(); 那這里應該是返回LiteJobConfiguration才對是己,Optional是個什么東東又兵??打開這個Optional看了一下類結構卒废,在guava包里沛厨,依賴如下:

<dependency>
     <groupId>com.google.guava</groupId>
     <artifactId>guava</artifactId>
     <version>18.0</version>
 </dependency>

? 原來是鼎鼎大名的guava,膜拜膜拜摔认。那么這個Optional到底是啥俄烁??看業(yè)務邏輯liteJobConfigFromZk.isPresent()應該是不為null的意思级野,看到不懂得地方页屠,趕快去總結總結Optional的用法和API:

  • 構造方法:該Optional接口實現類有兩個,一個為Absent蓖柔,一個為Present辰企,中文意思為缺席的,出席的况鸣,然后個人理解牢贸,Present為存在的,Absent為不存在的镐捧。
    • absent()
      • 返回absent對象
    • of(T t)
      • t不能為null潜索,否則拋異常
    • fromNullable(T t)
      • 可以為null臭增,為null時,構造absent對象竹习,否則構造Present
  • isPresent()
    • 是否是present誊抛,不是則為absent。
  • get()
    • 返回Optional包含的T實例整陌,若為null拗窃,拋異常
  • or(T)
    • 若Option包含了值,返回Optional包含的T泌辫,否則返回輸入的T實例作為默認值
  • orNull()
    • 返回Optional實例中包含的非空T實例随夸,如果Optional中包含的是空值,返回null;

在elasticJob中震放,節(jié)點不存在或者節(jié)點配置job的信息為null宾毒,返回Absent,否則返回Present殿遂。如果Job配置是present的狀態(tài)且作業(yè)監(jiān)聽類不一致诈铛,拋異常,檢查失敗勉躺。
這里是使用Optional代替了null值得判斷,具體帶來的好處觅丰,相信搜索一有很多鏈接都寫得很好饵溅。

Guava學習筆記:Optional優(yōu)雅的使用null
使用google guava的Optional接口來避免空指針錯誤

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市妇萄,隨后出現的幾起案子蜕企,更是在濱河造成了極大的恐慌,老刑警劉巖冠句,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件轻掩,死亡現場離奇詭異,居然都是意外死亡懦底,警方通過查閱死者的電腦和手機唇牧,發(fā)現死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來聚唐,“玉大人丐重,你說我怎么就攤上這事「瞬椋” “怎么了扮惦?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長亲桦。 經常有香客問我崖蜜,道長浊仆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任豫领,我火速辦了婚禮抡柿,結果婚禮上,老公的妹妹穿的比我還像新娘氏堤。我一直安慰自己沙绝,他們只是感情好,可當我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布鼠锈。 她就那樣靜靜地躺著闪檬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪购笆。 梳的紋絲不亂的頭發(fā)上粗悯,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天,我揣著相機與錄音同欠,去河邊找鬼样傍。 笑死,一個胖子當著我的面吹牛铺遂,可吹牛的內容都是我干的衫哥。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼襟锐,長吁一口氣:“原來是場噩夢啊……” “哼撤逢!你這毒婦竟也來了?” 一聲冷哼從身側響起粮坞,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤蚊荣,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后莫杈,有當地人在樹林里發(fā)現了一具尸體互例,經...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年筝闹,在試婚紗的時候發(fā)現自己被綠了媳叨。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出杏愤,到底是詐尸還是另有隱情,我是刑警寧澤扩然,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站聋伦,受9級特大地震影響夫偶,放射性物質發(fā)生泄漏界睁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一兵拢、第九天 我趴在偏房一處隱蔽的房頂上張望翻斟。 院中可真熱鬧,春花似錦说铃、人聲如沸访惜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽债热。三九已至,卻和暖如春幼苛,著一層夾襖步出監(jiān)牢的瞬間窒篱,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工舶沿, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留墙杯,地道東北人。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓括荡,卻偏偏與公主長得像高镐,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子畸冲,可洞房花燭夜當晚...
    茶點故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內容