Collections.sort 给集合排序

 1 List<MenuVo> child_menus = new ArrayList<MenuVo>();
 2 
 3                 for (MenuVo menuVo : child_menus) {
 4                     System.out.println("menuBVo=======" + menuVo.getSortId());
 5                 }
 6 
 7                 Collections.sort(child_menus, new Comparator<MenuVo>() {
 8                     public int compare(MenuVo arg0, MenuVo arg1) {
 9                         System.out.println(
10                                 "arg0.getSortId()-arg1.getSortId()=====" + (arg0.getSortId() - arg1.getSortId()));
11                         return arg0.getSortId() - arg1.getSortId(); // 按照sortid排列
12                     }
13                 });
14 
15                 for (MenuVo menuVo : child_menus) {
16                     System.out.println("menuBVo111=======" + menuVo.getSortId());
17                 }

效果

menuBVo=======5
menuBVo=======2
menuBVo=======7
menuBVo=======1
menuBVo=======4
menuBVo=======4
menuBVo=======3
menuBVo=======6
menuBVo=======0
menuBVo=======3
menuBVo=======6
menuBVo=======1
menuBVo=======2
menuBVo=======5
arg0.getSortId()-arg1.getSortId()=====-3
arg0.getSortId()-arg1.getSortId()=====5
arg0.getSortId()-arg1.getSortId()=====2
arg0.getSortId()-arg1.getSortId()=====-4
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====2
arg0.getSortId()-arg1.getSortId()=====0
arg0.getSortId()-arg1.getSortId()=====-3
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====1
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====2
arg0.getSortId()-arg1.getSortId()=====1
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====-4
arg0.getSortId()-arg1.getSortId()=====-3
arg0.getSortId()-arg1.getSortId()=====-2
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====1
arg0.getSortId()-arg1.getSortId()=====0
arg0.getSortId()-arg1.getSortId()=====2
arg0.getSortId()-arg1.getSortId()=====0
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====-3
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====0
arg0.getSortId()-arg1.getSortId()=====-2
arg0.getSortId()-arg1.getSortId()=====0
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====2
arg0.getSortId()-arg1.getSortId()=====-1
arg0.getSortId()-arg1.getSortId()=====1
arg0.getSortId()-arg1.getSortId()=====0
menuBVo111=======0
menuBVo111=======1
menuBVo111=======1
menuBVo111=======2
menuBVo111=======2
menuBVo111=======3
menuBVo111=======3
menuBVo111=======4
menuBVo111=======4
menuBVo111=======5
menuBVo111=======5
menuBVo111=======6
menuBVo111=======6
menuBVo111=======7

转载于:https://www.cnblogs.com/wangchuanqi/p/6003757.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用stream排序的方式是通过将集合转换成流,然后使用sorted方法进行排序。具体步骤如下: 1. 首先,将集合转换为流,可以使用stream()方法将集合转换为流,例如:List<Student> studentList = new ArrayList<>(); Stream<Student> studentStream = studentList.stream(); 2. 接下来,使用sorted方法进行排序。在sorted方法中,我们可以传入一个Comparator对象,用于指定排序的规则。比如,按照学生的年龄进行降序排序,可以使用Comparator.comparing方法,然后通过reversed方法进行降序排序。示例代码如下: studentList = studentList.stream() .sorted(Comparator.comparing(Student::getAge).reversed()) .collect(Collectors.toList()); 3. 最后,将排序后的流收集回集合中,可以使用collect方法将排序后的流收集成一个新的集合。示例代码如下: List<Student> sortedList = studentList.stream() .sorted(Comparator.comparing(Student::getAge).reversed()) .collect(Collectors.toList()); 请注意,以上代码只是示例,具体的排序规则和集合类型需要根据实际情况进行调整。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Java的集合排序Collections.sort、list.sort和list.stream().sorted方法详解](https://blog.csdn.net/qq_42971035/article/details/109132219)[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: 50%"] - *3* [性能对比:collections.sort vs treeSet sort vs java8 stream.sorted](https://blog.csdn.net/weixin_42306480/article/details/114207280)[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: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值