Java集合工具类

Java集合工具类:Collections
Java提供了一个操作Set、List和Map等集合的工具类:Collections,该工具类里提供了大量方法对集合元素进行排序、查询和修改等操作,还提供了对集合对象实现同步控制等方法。
一、排序操作:排序相关的、顺序相关的功能
(1)、reverse()反转指定列表中元素的顺序
(2)、shuffle()使用默认随机源对指定列表进行置换(每一次的顺序都不一样)或者打乱顺序 :打乱集合顺序
例子:Collections.shuffle(list);
System.out.println(list);
运行结果:
[a, d, b, c]

(3)、sort()根据指定比较器产生的顺序对指定列表进行排序(默认从小到大)或者在指定列表的指定位置处交换元素
注意:sort(list)有使用前提:被排序的集合元素必须实现了Comparable接口,重写接口中的compareTo方法定义排序的规则;
Comparable接口的排序规则:
①自己(this)- 参数:升序,
②参数 - 自己(this):降序。
在指定列表的指定位置处交换元素(规则排序)
注意:Comparator是一个接口,相当于找一个第三方的裁判,比较两个元素。
Comparator接口的排序规则:
①o1-o2:升序,
②o2-o1:降序,如果是一样的
(4)、swap()交换一下顺序
(5)、rotate()根据指定的距离轮换指定列表中的元素
二、查找和替换操作
(1)、max()根据元素的自然顺序,返回给定 collection 的最大元素
(2)、min()根据元素的自然顺序,返回给定 collection 的最小元素
(3)、replaceAll()使用另一个值替换列表中出现的所有某一指定值
(4)、frequency()返回指定 collection 中等于指定对象的元素数。
(5)、binarySearch()使用二分搜索法搜索指定列表,以获得指定对象。
例子 源代码:
在这里插入图片描述

结果:
在这里插入图片描述

(6)、indexOfSubList()查找子列表在列表中第一次出现的位置,没有返回-1
(7)、lastIndexOfSubList()查找子列表在列表中最后一次出现的位置,没有返回-1
(8)、fill()使用指定元素替换指定列表中的所有元素
三、同步控制
Collections类中提供了多个 synchronized…()方法,这些方法可以将指定集合包装成线程同步(线程安全)的集合,从而可以解决多线程并发访问集合时的线程安全问题。
Java中常用的集合框架中的实现类 ArrayList、Linkedlist、 HashSet、TreeSet、 HashMap和TreeMap
都是线程不安全的。如果有多个线程访问它们,而且有超过一个的线程试图修改它们,则存在线程安全的问题。
Collections提供了多个类方法可以把它们包装成线程同步的集合。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java提供了许多集合类,每个类都有自己的拷贝方法。如果你想要一个通用的集合拷贝工具类,你可以自己编写一个或者使用Apache Commons Collections库中的CollectionUtils类。 下面是一个示例的集合拷贝工具类,它基于Java的原生集合类实现: ```java import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class CollectionCopyUtils { public static <T> List<T> copyList(List<T> sourceList) { if (sourceList == null) { return null; } List<T> copyList = new ArrayList<>(sourceList.size()); for (T item : sourceList) { copyList.add(item); } return copyList; } public static <K, V> Map<K, V> copyMap(Map<K, V> sourceMap) { if (sourceMap == null) { return null; } Map<K, V> copyMap = new HashMap<>(sourceMap.size()); for (Map.Entry<K, V> entry : sourceMap.entrySet()) { copyMap.put(entry.getKey(), entry.getValue()); } return copyMap; } } ``` 使用示例: ```java import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class Main { public static void main(String[] args) { // 测试List拷贝 List<String> sourceList = new ArrayList<>(); sourceList.add("A"); sourceList.add("B"); sourceList.add("C"); List<String> copiedList = CollectionCopyUtils.copyList(sourceList); System.out.println("Copied List: " + copiedList); // 测试Map拷贝 Map<Integer, String> sourceMap = new HashMap<>(); sourceMap.put(1, "One"); sourceMap.put(2, "Two"); sourceMap.put(3, "Three"); Map<Integer, String> copiedMap = CollectionCopyUtils.copyMap(sourceMap); System.out.println("Copied Map: " + copiedMap); } } ``` 这个示例工具类提供了copyList和copyMap方法,分别用于拷贝List和Map集合。你可以根据自己的需要进行相应的修改和扩展。希望能对你有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值