Comparator类中的compare(T o1,T o2)和compareTo()的使用与疑惑解答

这几天做项目刚好遇到需要排序的需求,大概就是你查询一个list,然后list中保存的是map数据,你需要根据map中的若干个数据排序,比如说

List<Map<String, Object>> list = new ArrayList<>();
		Map<String, Object> yuan = new HashMap<>();
		yuan.put("type", 7);
		yuan.put("code", "c");
		Map<String, Object> jia = new HashMap<>();
		jia.put("type", 1);
		jia.put("code", "b");
		Map<String, Object> min = new HashMap<>();
		min.put("type", 6);
		min.put("code", "a");
		Map<String, Object> min2 = new HashMap<>();
		min2.put("type", 5);
		min2.put("code", "d");
		Map<String, Object> min3 = new HashMap<>();
		min3.put("type", 8);
		min3.put("code", "e");
		Map<String, Object> min4 = new HashMap<>();
		min4.put("type", 7);
		min4.put("code", "h");
		Map<String, Object> min5 = new HashMap<>();
		min5.put("type", 7);
		min5.put("code", "f");
		
		System.out.println("tttttttttttttttt"+min5.get("type"));
		
		list.add(min);//6 a
		list.add(min2);//5 d
		list.add(min3);//8 e
		list.add(min4);//7 h
		list.add(min5);//7 f
		list.add(jia);//1 b
		list.add(yuan);//7 c

这个里面我需要”先将type为7的优先排序置顶,然后剩下的根据code倒序排序“相信第一次碰到这个的朋友是一头雾水,但是compare和compareTo就能很好的解决这个问题。接下来你们先思考一下这个需求,要是你你会怎么做,接下来我会先将思路,然后顺带将这两个方法在其中的应用做一一解释。

思路:(相当于if-else的思路)如果两个比较的数据为7我们就将这两个数据根据code值排序,如果两个值一个是7一个是别的值,我们就将7排在这个值的前面,如果两个type都不是7,我们就优先比较type值,如果比较的是字符,那么compareTo比较的两个字符的acsII码

大概思路就是上面这个意思,然后我贴实现代码并把我开始学的时候迷茫的问题进行解答

1《compare(T o1, T o2)是中的o1,o2代表什么,是怎么实现排序的?怎么和compareTo()配合使用?

答:o1和o2每次只取一个数据,就一次只比较两个数据,假如比较7,8,9,5,6,那么第一次比较o1先取8,o2取7(很奇怪,我当时以为是顺着取值,但是很奇怪,他是相邻两个值逆着取值,但不管他,开心就好),接下来配合compareTo()实现这两个数的排序,o1.compareTo(o2)会返回一个int值,如果0说明o1和o2相等,如果返回负值,那么o1和o2会倒序排序,返回正值,那么o1和o2会正序排序。返回值之后这两个值就进行了排序,至此,这两个值已经排序好了,接下来第二次排序,o1取9,o2取8,第三次o1取5,o2取9.....

2《怎么进行多条件排序?

答:通过if进行条件筛选,看代码,下面我就将上面实现需求的代码实现,可以自己复制运行一下,有不懂的可以私信我

System.out.println(list);
		Collections.sort(list, new Comparator<Map<String, Object>>() {

			@Override
			public int compare(Map<String, Object> o1, Map<String, Object> o2) {
				System.out.println("o1="+o1);
				System.out.println("o2="+o2);//== null ? "" : o1.get("name").toString()
				String a  = (o1.get("Tsype") == null ? "" : o1.get("TYspe").toString()).indexOf("7")+"";
				System.out.println("TYpe="+o1.get("type")+"     a="+a);
				String b  = (o2.get("TYpe") == null ? "" : o2.get("TYpe").toString()).indexOf("7")+"";
				
				System.out.println("type="+o2.get("type")+"     b="+b);
				System.out.println();
				if (a.equals(b)) {
					System.out.println("o1.code="+o1.get("code"));
					System.out.println("o2.code="+o2.get("code"));
					System.out.println((o2.get("code")+"").compareTo(o1.get("code")+ ""));
					System.out.println("===============================================");
					return (o2.get("code")+"").compareTo(o1.get("code")+ "");
				}
				System.out.println( b.compareTo(a));
				System.out.println("---------------------------------------------------");
				return b.compareTo(a);
			}
		});
		System.out.println("最后显示的list="+list);
	}

开始学的时候多打一点syso,看一下规则,一点一点找规则,看一下大手子是怎么做的,哈哈,不懂下面私我

  • 7
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值