java8stream自定义分组求和并排序的实现

本文主要介绍了java8 stream自定义分组求和并排序的实现,分享给大家,具体如下:

创新互联建站拥有一支富有激情的企业网站制作团队,在互联网网站建设行业深耕十年,专业且经验丰富。十年网站优化营销经验,我们已为成百上千中小企业提供了做网站、成都做网站解决方案,按需网站制作,设计满意,售后服务无忧。所有客户皆提供一年免费网站维护!

  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());
  }
}

结果:

java8 stream自定义分组求和并排序的实现

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

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

但是结果不正确

java8 stream自定义分组求和并排序的实现

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。

新闻标题:java8stream自定义分组求和并排序的实现
网站地址:https://www.cdcxhl.com/article44/pdjoee.html

成都网站建设公司_创新互联,为您提供响应式网站网站维护网站建设电子商务移动网站建设网站内链

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

搜索引擎优化