java8中怎么利用stream自定义分组求和并排序

本篇文章为大家展示了java8中怎么利用stream自定义分组求和并排序,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

创新互联建站专注为客户提供全方位的互联网综合服务,包含不限于成都网站建设、成都网站设计、蕉城网络推广、微信平台小程序开发、蕉城网络营销、蕉城企业策划、蕉城品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联建站为所有大学生创业者提供蕉城建站搭建服务,24小时服务热线:028-86922220,官方网址:www.cdcxhl.com

具体如下:

public static void main(String[] args) {    List 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 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 {  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());  }}

结果:

上述代码实现对对象GroupDetailDTO按设备和时间分组求played的和,并且按时间排序了。当初想着既然是按时间排序那么compareTo方法直接使用

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

但是结果不正确

分析:分组求和时如果使用了排序,那么分组时对相同属性的合并将直接根据compareTo返回的结果合并对象,所以如果用上述方法将产生相同的时间直接合并,而不是new GroupDetailDTO(o.getHeadsetId(), o.getTime())里面的两个属性都相同才合并。

上述内容就是java8中怎么利用stream自定义分组求和并排序,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


本文标题:java8中怎么利用stream自定义分组求和并排序
链接URL:http://ybzwz.com/article/pjhesc.html