溫馨提示×

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

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

java8中怎么利用stream自定義分組求和并排序

發(fā)布時(shí)間:2021-08-06 16:17:53 來源:億速云 閱讀:200 作者:Leah 欄目:編程語言

本篇文章為大家展示了java8中怎么利用stream自定義分組求和并排序,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

具體如下:

public static void main(String[] args) {    List<GroupDetailDTO> list = new ArrayList<>();    GroupDetailDTO dto1 = new GroupDetailDTO();    dto1.setHeadsetId(1);    dto1.setTime("2020-01-03");    dto1.setActConcreteTime("a");    dto1.setPlayed(1);    list.add(dto1);    GroupDetailDTO dto2 = new GroupDetailDTO();    dto2.setHeadsetId(1);    dto2.setTime("2020-01-01");    dto2.setActConcreteTime("b");    dto2.setPlayed(1);    list.add(dto2);    GroupDetailDTO dto3 = new GroupDetailDTO();    dto3.setHeadsetId(1);    dto3.setTime("2020-01-02");    dto3.setActConcreteTime("c");    dto3.setPlayed(1);    list.add(dto3);    GroupDetailDTO dto4 = new GroupDetailDTO();    dto4.setHeadsetId(2);    dto4.setTime("2020-01-01");    dto4.setActConcreteTime("d");    dto4.setPlayed(4);    list.add(dto4);    Map<GroupDetailDTO, Integer> collect = list.stream().collect(Collectors.groupingBy(o -> new GroupDetailDTO(o.getHeadsetId(), o.getTime()), TreeMap::new, Collectors.summingInt(o -> o.getPlayed())));    collect.forEach((k, v) -> {      System.out.println(k + "@@@" + v);    });  }

@Datapublic class GroupDetailDTO implements Comparable<GroupDetailDTO> {  private Integer headsetId;  private String actConcreteTime;  private String time;  private Integer played;  public GroupDetailDTO() {  }  public GroupDetailDTO(Integer headsetId, String time) {    this.headsetId = headsetId;    this.time = time;  }  @Override  public int compareTo(GroupDetailDTO o) {    String a = this.headsetId + "|" + this.getTime();    String b = o.getHeadsetId() + "|" + o.getTime();    return a.compareTo(b);//    return this.getTime().compareTo(o.gtTime());  }}

結(jié)果:

上述代碼實(shí)現(xiàn)對(duì)對(duì)象GroupDetailDTO按設(shè)備和時(shí)間分組求played的和,并且按時(shí)間排序了。當(dāng)初想著既然是按時(shí)間排序那么compareTo方法直接使用

return this.getTime().compareTo(o.getTime());

但是結(jié)果不正確

分析:分組求和時(shí)如果使用了排序,那么分組時(shí)對(duì)相同屬性的合并將直接根據(jù)compareTo返回的結(jié)果合并對(duì)象,所以如果用上述方法將產(chǎn)生相同的時(shí)間直接合并,而不是new GroupDetailDTO(o.getHeadsetId(), o.getTime())里面的兩個(gè)屬性都相同才合并。

上述內(nèi)容就是java8中怎么利用stream自定義分組求和并排序,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(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