JDK 1.8 List 多次 分组

在公司的一个新需求中,需要对list中进行分组,用了一大段繁琐大代码进行实现,结果发现JDK1.8有这个功能,真是太强大了


public static void main(String[] args){
//无视对象,在此记录,以防遗忘
//两次 groupBy
    List<RStudentExam> list = new ArrayList<>();

    RStudentExam rse1 = new RStudentExam();
    rse1.setId(1L);
    rse1.setSchoolId(1L);
    rse1.setStudentId(3L);
    list.add(rse1);

    RStudentExam rse2 = new RStudentExam();
    rse2.setId(1L);
    rse2.setSchoolId(2L);
    rse2.setStudentId(3L);
    list.add(rse2);

    RStudentExam rse3 = new RStudentExam();
    rse3.setId(2L);
    rse3.setSchoolId(1L);
    rse3.setStudentId(3L);
    list.add(rse3);

    RStudentExam rse4 = new RStudentExam();
    rse4.setId(2L);
    rse4.setSchoolId(2L);
    rse4.setStudentId(3L);
    list.add(rse4);

    RStudentExam rse5 = new RStudentExam();
    rse5.setId(2L);
    rse5.setSchoolId(2L);
    rse5.setStudentId(3L);
    list.add(rse5);

    Map<Long,Map<Long,List<RStudentExam>>> map = list
            .stream()
            .collect(Collectors.groupingBy(RStudentExam::getId,Collectors.groupingBy(RStudentExam::getSchoolId)));
}



下面是JDK1.8进行去重


List<NoteDesc> noteDescs =  null ;
Map<String, Object> maps =  new  HashMap<>();
 
List<NoteDesc> descs = noteDescDao.findAll();
 
// 根据noteId去重
List<NoteDesc> lists = descs.
        stream().
        collect(collectingAndThen(toCollection(() -> 
                new  TreeSet<>(Comparator.comparing(NoteDesc::getNoteID))), ArrayList:: new ));
 
for  (NoteDesc noteDesc : lists) {
     noteDescs =  new  ArrayList<>();
     for  (NoteDesc desc : descs) {
        if (noteDesc.getNoteID() == desc.getNoteID()) {
             noteDescs.add(desc);
         }
     }
     maps.put(noteDesc.getNoteName(), noteDescs);
}
 
return  maps;

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
JDK 1.8中,Java的内存模型可以从以下几个方面来介绍: 1. 程序计数器:程序计数器是一块较小的内存区域,它可以看作是当前线程所执行的字节码的行号指示器。每个线程都有自己的程序计数器,线程切换时会保存当前线程的程序计数器值并恢复另一个线程的程序计数器值。程序计数器是线程私有的,它的作用是保证线程切换后能正确地恢复到正确的执行位置。 2. Java堆:Java堆是用于存储对象实例的内存区域。在JDK 1.8中,Java堆被划分为两个部分,新生代和老年代。新生代用于存放新创建的对象,而老年代用于存放经过多次垃圾回收仍然存活的对象。Java堆是所有线程共享的内存区域。 3. 方法区:方法区是用于存储类信息、常量、静态变量等数据的内存区域。在JDK 1.8中,方法区被替代为元空间(Metaspace)。与永久代不同,元空间并不在虚拟机中,而是使用本地内存。 4. 虚拟机栈:虚拟机栈用于存储方法调用的局部变量、方法参数、返回值等信息。每个方法在执行时都会创建一个栈帧,用于存储方法的局部变量和方法调用相关的信息。虚拟机栈是线程私有的,每个线程都有自己的虚拟机栈。 5. 本地方法栈:本地方法栈类似于虚拟机栈,但是它是为本地方法服务的。本地方法栈用于存储本地方法的参数和局部变量。 6. 程序的运行时常量池:运行时常量池是方法区的一部分,用于存放编译时期生成的各种字面量和符号引用。 7. 直接内存:直接内存并不是虚拟机运行时数据区的一部分,但是它可以被JVM所管理。直接内存是使用NIO(New Input/Output)类库进行I/O操作时分配的一块内存,它通过与操作系统直接交互来分配和释放内存。 以上是JDK 1.8的内存模型的主要内容。不同的内存区域在Java程序的执行过程中起着不同的作用,并且相互之间有一定的关联和交互关系。了解内存模型的结构和特点对于Java程序的开发和调优都非常重要。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [jdk1.8的jvm内存模型——实习生必须了解的](https://download.csdn.net/download/weixin_38516040/13747048)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [JDK1.8 JVM内存模型](https://blog.csdn.net/lwb3035/article/details/95190547)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [JDK1.8 JVM运行时数据区域划分](https://blog.csdn.net/bruce128/article/details/79357870)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值