本文主要介紹了java8 stream自定義分組求和并排序的實現(xiàn),分享給大家,具體如下:
創(chuàng)新互聯(lián)建站擁有一支富有激情的企業(yè)網站制作團隊,在互聯(lián)網網站建設行業(yè)深耕十年,專業(yè)且經驗豐富。十年網站優(yōu)化營銷經驗,我們已為成百上千中小企業(yè)提供了做網站、成都做網站解決方案,按需網站制作,設計滿意,售后服務無憂。所有客戶皆提供一年免費網站維護!
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); }); }
@Data public 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()); } }
結果:
上述代碼實現(xiàn)對對象GroupDetailDTO按設備和時間分組求played的和,并且按時間排序了。當初想著既然是按時間排序那么compareTo方法直接使用
return this.getTime().compareTo(o.getTime());
但是結果不正確
分析:分組求和時如果使用了排序,那么分組時對相同屬性的合并將直接根據(jù)compareTo返回的結果合并對象,所以如果用上述方法將產生相同的時間直接合并,而不是new GroupDetailDTO(o.getHeadsetId(), o.getTime())里面的兩個屬性都相同才合并。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
新聞標題:java8stream自定義分組求和并排序的實現(xiàn)
網站地址:http://muchs.cn/article44/pdjoee.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供響應式網站、網站維護、網站建設、電子商務、移動網站建設、網站內鏈
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)