用代码对集合进行排序

业务1
根据业务需求,需要在代码中对list集合进行排序。
一个项目可以归类为A-D类的其中一类或多类,分类等级从A-D由大到小排列。以2的n次方对A-D类的权重进行赋值后进行排序。

      //从大到小排序
		Collections.sort(result, new Comparator<ValueVo>() {
			public int compare(ValueVo o1, ValueVo o2) {
				//排名设置 A类(8)>B类(4)>C类(2)>D类(1)
				int value1 = 0;
				int value2 = 0;
                //根据权重对权重总值进行赋值				
				if(StringUtils.isNotEmpty(o1.getType1())&&o1.getType1().equals("A"))value1 = value1 + 8;
				if(StringUtils.isNotEmpty(o1.getType2())&&o1.getType2().equals("B"))value1 = value1 + 4;
				if(StringUtils.isNotEmpty(o1.getType3())&&o1.getType3().equals("C"))value1 = value1 + 2;
				if(StringUtils.isNotEmpty(o1.getType4())&&o1.getType4().equals("D"))value1 = value1 + 1;
				
				if(StringUtils.isNotEmpty(o2.getType1())&&o2.getType1().equals("A"))value2 = value2 + 8;
				if(StringUtils.isNotEmpty(o2.getType2())&&o2.getType2().equals("B"))value2 = value2 + 4;
				if(StringUtils.isNotEmpty(o2.getType3())&&o2.getType3().equals("C"))value2 = value2 + 2;
				if(StringUtils.isNotEmpty(o2.getType4())&&o2.getType4().equals("D"))value2 = value2 + 1;
				
				//如果前者的权重值大于后者的权重值,就是前者大于后者-1,返回1系统就会识别是后者大于前者
				if (value1 > value2) {
					return -1;//改变为1则从小到大
				}
				//小于同理
				if (value1 < value2) {
					return 1;
				}
				//如果返回0则认为前者与后者相等
				return 0;
			}
		});

业务2
在这里插入图片描述
有以上表格,项目用到A-D类材料,重要性从A-D由大到小排列,A-D类的用量为表格中的数据,现在要对项目进行排序,顺序为A类材料用量>B类材料用量。。。。。,A类相同则比较B类的数量,以此类推。

rankList = rankList.stream().sorted(Comparator
				.comparing(RankVo::getA,Comparator.reverseOrder())
				.thenComparing(RankVo::getB,Comparator.reverseOrder())
				.thenComparing(RankVo::getC,Comparator.reverseOrder())
				.thenComparing(RankVo::getD,Comparator.reverseOrder())).collect(Collectors.toList());

代码的内容是从上到下,先对A进行降序,再对B进行降序,以此类推。
.naturalOrder()–升序
.reverseOrder()–降序
但是这个方法存在一个问题,就是当数值为空的时候会抛出异常

The returned comparator is serializable and throws NullPointerException when comparing null.

后面找了相关资料,解决了这个问题,找到如下写法:

rankList = rankList.stream().sorted(Comparator
				.comparing(RankVo::getA,Comparator.nullsLast(Comparator.reverseOrder()))
				.thenComparing(RankVo::getB,Comparator.nullsLast(Comparator.reverseOrder()))
				.thenComparing(RankVo::getC,Comparator.nullsLast(Comparator.reverseOrder()))
				.thenComparing(RankVo::getD,Comparator.nullsLast(Comparator.reverseOrder()))).collect(Collectors.toList());

nullsLast–空值排最后
nullsFirst–空值排最前

如果用List<Map<String,Object>>的方式对数据进行存储后排序的话

mapList = mapList.stream().sorted(Comparator
				.comparing(o -> Integer.valueOf(String.valueOf(((Map) o).get("A"))),Comparator.reverseOrder())
				.thenComparing(o -> Integer.valueOf(String.valueOf(((Map) o).get("B"))),Comparator.reverseOrder())
				.thenComparing(o -> Integer.valueOf(String.valueOf(((Map) o).get("C"))),Comparator.reverseOrder())
				.thenComparing(o -> Integer.valueOf(String.valueOf(((Map) o).get("D"))),Comparator.reverseOrder())
				).collect(Collectors.toList());
		map.put("table", mapList);

业务3
在这里插入图片描述

有以上表格,项目类型为A/B/C类,重要性从A-C由大到小排列;材料类型重要性为1-3,用量为表格中的数据。现在要对项目进行排序,先按项目分类排序,再按各材料用量排序。
可以将项目分类按业务1的方法转换为对应权重,然后再用业务2的方法进行排序。

下面这个文章可以看看,对这个排序的理解可以加深

参考内容 https://www.cnblogs.com/igoodful/p/9517784.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值