网站首页 > 开源技术 正文
该系列为java工具类系列,主要展示100个常用的java工具类。
此文重点讲述:多种集合类型实现排序功能,另外还有Collections其他工具类的讲解。
1)Collections工具类是一个专门用来操作Set,List,Map等集合的工具类。
2)Collections工具类提供了一系列静态方法对集合元素进行排序、查询、修改等操作。
一、List<Map<String, Object>>根据Map的key实现排序(本文重点)
List<Map<String, Object>> list = new ArrayList<>();
Map<String, Object> map1 = new HashMap<>();
map1.put("key", "张三");
Map<String, Object> map2 = new HashMap<>();
map2.put("key", "王五");
Map<String, Object> map3 = new HashMap<>();
map3.put("key", "李四");
list.add(map1);
list.add(map2);
list.add(map3);
Collections.sort(list, new Comparator<Map<String, Object>>() {
@Override
public int compare(Map<String, Object> map1, Map<String, Object> map2) {
String name1 = (String)map1.get("key");
String name2 = (String)map2.get("key");
//实现中文排序(按照中文首字母),如果key是数值型,此行删除
Collator instance = Collator.getInstance(Locale.CHINA);
//实现正序,如果想实现倒序,修改name1和name2顺序即可
return instance.compare(name1, name2);
}
});
System.out.println(list.toString());
执行结果:[张三, 李四, 王五]
二、List<Integer>实现排序
List<Integer> list = new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
Collections.sort(list);//升序
System.out.println(list);
Collections.reverse(list);//降序
System.out.println(list);
执行结果:[1, 2, 3]
执行结果:[3, 2, 1]
三、Collections的拓展功能
3.1,获取集合中的最大值或者最小值,使用Collections的max和min方法实现。
List<Integer> list = new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
Integer max = Collections.max(list);//获取最大值
Integer min = Collections.min(list);//获取最小值
System.out.println(max);
System.out.println(min);
执行结果:3
执行结果:1
3.2,统计集合中某个元素出现的次数,使用Collections的frequency方法实现。
//返回指定集合中指定元素的出现次数
List<String> list = new ArrayList<>();
list.add("1");
list.add("2");
list.add("2");
list.add("3");
int count = Collections.frequency(list, "2");
System.out.println(count);
执行结果:2
3.3,转换线程安全集合,使用Collections的synchronizedxxx方法实现。
java中的很多集合,比如:ArrayList、LinkedList、HashMap、HashSet等,都是线程不安全的。在特定场景下,我们需要线程安全的集合,因此需要进行转换。
List<Integer> list = new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
//将ArrayList转换成线程安全集合
List<Integer> tatList = Collections.synchronizedList(list);
System.out.println(tatList);
猜你喜欢
- 2025-07-24 十大经典排序算法-堆排序,计数排序,桶排序,基数排序
- 2025-07-24 halcon select_shape算子(halcon算子中文手册)
- 2025-07-24 spring如何让我们的拦截器顺序放最后执行#java
- 2025-07-24 怎么求第K大的数,topK 问题(快排的应用)java
- 2025-07-24 Java 最细的集合类总结(java集合有那些)
- 2025-07-24 低成本高性能AI开发神器!极摩客EVO-X2桌面Mini AI工作站深度评测
- 2025-07-24 吊打面试官(十五)--Java语言中HashMap类一文全掌握
- 2025-07-24 用动态规划怎么求最大子序列和打家劫舍问题Java
- 2025-07-24 线程池最佳线程数量到底要如何配置?
- 2025-07-24 Java泛型详解,通俗易懂只需5分钟
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)