91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java8 stream自定義分組求和并排序的實現

發布時間:2020-10-18 16:09:42 來源:腳本之家 閱讀:262 作者:shuangyueliao 欄目:編程語言

本文主要介紹了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())里面的兩個屬性都相同才合并。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

都昌县| 枣阳市| 临沧市| 合肥市| 甘洛县| 怀仁县| 米易县| 双辽市| 北海市| 江源县| 新郑市| 南丹县| 富平县| 都匀市| 景东| 西乌珠穆沁旗| 济源市| 东安县| 若尔盖县| 铜梁县| 诸城市| 纳雍县| 安化县| 龙口市| 神池县| 丰都县| 滁州市| 新营市| 栖霞市| 和静县| 阜南县| 青铜峡市| 神农架林区| 镇赉县| 乐陵市| 楚雄市| 尚志市| 东至县| 汉寿县| 长白| 汾西县|