java8中compute和merge方法如何使用,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
成都創(chuàng)新互聯-專業(yè)網站定制、快速模板網站建設、高性價比盈江網站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式盈江網站制作公司更省心,省錢,快速模板網站建設找我們,業(yè)務覆蓋盈江地區(qū)。費用合理售后完善,10多年實體公司更值得信賴。
基礎數據:
KeyAndValue a1 = new KeyAndValue().setName("kevin").setValue("lee"); KeyAndValue a5 = new KeyAndValue().setName("kevin2").setValue("lee5"); KeyAndValue a6 = new KeyAndValue().setName("kevin3").setValue("lee8");
場景一對應的方法是compute方法
compute,對key存在的元素進行加工,并返回加工后的元素,同時map中該元素也被替換成加工后的。如果對value進行計算或邏輯處理,必須保證value非null。示例如下:
Mapmaps = new HashMap<>(); maps.put("a",a1); System.out.println(maps); {a=KeyAndValue(name=kevin, value=lee)}//key存在時KeyAndValue compute1 = maps.compute("a", (k, v) -> { Optional.ofNullable(v).ifPresent(v1 -> v1.setValue(v.getValue().concat("__ddddd")));return v; }); System.out.println(compute1);// KeyAndValue(name=kevin, value=lee__ddddd)System.out.println(maps);// {a=KeyAndValue(name=kevin, value=lee__ddddd)}// key不存在時KeyAndValue compute = maps.compute("b", (k, v) -> { Optional.ofNullable(v).ifPresent(v1 -> v1.setValue(v.getValue().concat("__ddddd")));return v; }); System.out.println(compute);//nullSystem.out.println(maps);// {a=KeyAndValue(name=kevin, value=lee__ddddd)}
當然針對value不存在和存在,也有針對性的方法(computeIfAbsent和computeIfPresent)。
computeIfAbsent
key不存在或null,則處理,返回處理后結果,并更新value;
//key不存在或nullMapmap = new HashMap<>(); System.out.println(map);//{}KeyAndValue computeIfAbsent = map.computeIfAbsent("a", s -> {return a6; }); System.out.println(computeIfAbsent);// KeyAndValue(name=kevin3, value=lee8)System.out.println(map);// {a=KeyAndValue(name=kevin3, value=lee8)}
key存在,則不進行處理,返回value,不更新map。示例如下:
// key存在。不進行任何處理,返回valueMapmap = new HashMap<>(); map.put("a",a1); System.out.println(map);// {a=KeyAndValue(name=kevin, value=lee)}KeyAndValue computeIfAbsent1 = map.computeIfAbsent("a", s -> {return a6; }); System.out.println(computeIfAbsent1);// KeyAndValue(name=kevin, value=lee)System.out.println(map);// {a=KeyAndValue(name=kevin, value=lee)}
computeIfPresent,
key存在則處理,返回處理后結果,并更新value;
//key存在則處理Mapmap = new HashMap<>(); map.put("a",a1); System.out.println(map);// {a=KeyAndValue(name=kevin, value=lee)}KeyAndValue computeIfPresent = map.computeIfPresent("a", (k, v) -> {return v.setValue(v.getValue().concat("_00000")); }); System.out.println(computeIfPresent);// KeyAndValue(name=kevin, value=lee_00000)System.out.println(map);// {a=KeyAndValue(name=kevin, value=lee_00000)}
key不存在或null,則不進行處理,返回null,不更新value
//key不存在則處理Mapmap = new HashMap<>();// map.put("a",null);System.out.println(map);//{}KeyAndValue computeIfPresent = map.computeIfPresent("a", (k, v) -> {return v.setValue(v.getValue().concat("_00000")); }); System.out.println(computeIfPresent);// nullSystem.out.println(map);// {}
場景二對應的方法merge
merge:對key存在的元素進行合并,并返回加工后的元素
a6就是合進來的新值,a6和newV是同一對象,所以newV和a6可互換;
oldV是map中原有key對應的值,oldV有值則合并,無值則新增對應的k和value=newV的鍵值對
Mapmap = new HashMap<>(); map.put("a",a1); System.out.println(map);// {a=KeyAndValue(name=kevin, value=lee)}
//“a”有值,則合并KeyAndValue merge = map.merge("a", a6, (oldV, newV) -> { oldV.setValue(newV.getValue()+"___"+oldV.getValue());return oldV; }); System.out.println(merge);// KeyAndValue(name=kevin, value=lee8___lee)System.out.println(map);// {a=KeyAndValue(name=kevin, value=lee8___lee)}//“b”無值,則新增"b":newVKeyAndValue merge1 = map.merge("b", a5, (oldV, newV) -> { oldV.setValue(oldV.getValue()+"___"+oldV.getValue());return oldV; //a5就是合進來的新值,a5和newV是同一對象,所以newV和a5可互換; // oldV是map中原有key=“b”對應的值,oldV有值則合并,無值則新增}); System.out.println(merge1);// KeyAndValue(name=kevin2, value=lee5)System.out.println(map);// {a=KeyAndValue(name=kevin, value=lee), b=KeyAndValue(name=kevin2, value=lee5)}
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯行業(yè)資訊頻道,感謝您對創(chuàng)新互聯的支持。