溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么在java8中使用stream 操作map

發(fā)布時(shí)間:2021-06-04 17:16:14 來(lái)源:億速云 閱讀:345 作者:Leah 欄目:編程語(yǔ)言

這篇文章給大家介紹怎么在java8中使用stream 操作map,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

1、map 根據(jù)value排序

Map<String,BigDecimal> map =new HashMap<>();
map.put("one", 0.08);
map.put("two", 0.1);
map.put("three", 0.2);
map.put("four", 0.91);

上面是項(xiàng)目中的一個(gè)中間結(jié)果,我們需要對(duì)這個(gè)map根據(jù)value值倒序排序,下面給出工具類:

  public <K, V extends Comparable<? super V>> Map<K, V> sortByValue(Map<K, V> map) {
    Map<K, V> result = new LinkedHashMap<>();
 
    map.entrySet().stream()
        .sorted(Map.Entry.<K, V>comparingByValue()
            .reversed()).forEachOrdered(e -> result.put(e.getKey(), e.getValue()));
    return result;
  }

當(dāng)然如果我們想根據(jù)map的key進(jìn)行排序,需要對(duì)上面的工具類進(jìn)行小小的修改,代碼如下:

 public <K extends Comparable<? super K>, V > Map<K, V> sortByKey(Map<K, V> map) {
    Map<K, V> result = new LinkedHashMap<>();
 
    map.entrySet().stream()
        .sorted(Map.Entry.<K, V>comparingByKey()
            .reversed()).forEachOrdered(e -> result.put(e.getKey(), e.getValue()));
    return result;
  }

我們可以看到,如果我們需要根據(jù)key排序,就需要讓key 繼承 Comparable ,也就說(shuō)我們需要對(duì)待排序的字段繼承 Comparable接口。另一個(gè)問(wèn)題就是,上面的這種寫法排序效果是 降序排序,如果我們需要升序排序的話,只需要將上面的.reversed()關(guān)鍵字限制去掉即可。

 public <K, V extends Comparable<? super V>> Map<K, V> sortByValue(Map<K, V> map) {
    Map<K, V> result = new LinkedHashMap<>();
 
    map.entrySet().stream()
        .sorted(Map.Entry.<K, V>comparingByValue()
            ).forEachOrdered(e -> result.put(e.getKey(), e.getValue()));
    return result;
  }

關(guān)于怎么在java8中使用stream 操作map就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI