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

站长

发表文章数:3062

牛客在线编程_牛牛的背包问题

    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自定义分组求和并排序

Elastcisearch.Nest 7.x 系列`伪`官方翻译:通过 NEST 来快捷试用 Elasticsearch

上述代码实现对对象GroupDetailDTO按设备和时间分组求played的和,并且按时间排序了。当初想着既然是按时间排序那么compareTo方法直接使用
return this.getTime().compareTo(o.getTime());
但是结果不正确
java8 stream自定义分组求和并排序

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

shell 条件测试

未经允许不得转载:www.xssyun.com作者:站长, 转载或复制请以 超链接形式 并注明出处 xss云之家-资源网,新人技术交流平台,一个湖北娃的个人博客
原文地址:《java8 stream自定义分组求和并排序》 发布于2020-01-24

分享到:
赞(0) 生成海报

长按图片转发给朋友

投稿赚钱
2020年在家赚取零花钱
切换注册

登录

忘记密码 ?

您也可以使用第三方帐号快捷登录

Q Q 登 录
微 博 登 录
切换登录

注册