真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯網站制作重慶分公司

java8中compute和merge方法如何使用

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。示例如下:

Map maps = 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不存在或nullMap map = 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存在。不進行任何處理,返回valueMap map = 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存在則處理Map map = 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不存在則處理Map map = 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
就是合進來的新值,a6newV是同一對象,所以newVa6可互換;
oldVmap中原有key對應的值,oldV有值則合并,無值則新增對應的kvalue=newV的鍵值對

Map map = 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)新互聯的支持。


分享題目:java8中compute和merge方法如何使用
URL網址:http://weahome.cn/article/ghesog.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部