您好,登錄后才能下訂單哦!
本篇文章為大家展示了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è)資訊頻道。
免責(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)容。