Collection常用工具类

Collections工具类
该工具类提供了大量针对Collection/Map的操作,总体可分为四类,都为静态(staic)方法:

1、排序操作(主要针对List接口相关)
reverse(List list):反转指定List集合中元素的顺序
shuffle(List list):对List中的元素进行随机排序(洗牌)
sort(List list):对List里的元素根据自然升序排序
sort(List list,Comparator c):自定义比较器进行排序
swap(List list,int i,int j):将指定List集合中i 处元素和j 处元素进行交换
rotate(List list,int distance):将所有元素向右移位指定长度,如果distance等于size那么结果不变

2、查找和替换(主要针对Collection接口相关)
binarySearch(List list,Object key):使用二分法查找,以获得指定对象在List中的索引,前提是集合已经排序
max(Collection coll):返回最大元素
max(Collection coll,Comparator comp):根据自定义比较器,返回最大元素
min(Collection] coll):返回最小元素
min(Collection coll,Comparator comp):根据自定义比较器,返回最小元素
fill(List list,Object obj):使用指定对象填充
frequency(Collection Object obj):返回指定集合中指定对象出现的次数
replaceAll(List list,Object old,Object new):替换


3、同步控制
Collections工具类提供了多个synchronizedXxx方法,该方法返回指定集合对象对应的同步对象,从而解决多线程并发访问集合时
线程的安全问题。HashSet、ArrayList、HashMap都是线程不安全的,如果需要考虑同步,则使用这些方法。这些方法主要有:synchronizedSet、synchronizedSortedSet、synchronizedList、synchronizedMap、synchronizedSortedMap
特别需要注意:在使用迭代方法遍历集合时需要手工同步返回的集合。{否则会有线程安全的问题}

4、设置不可变得结合
Collections工具类有三种方法返回一个不可变集合
emptyXxx():        返回一个空的不可变的集合对象
singletonXxx():    返回一个只包含指定对象的,不可变的集合对象
unmodifiableXxx(): 返回指定集合对象的不可变视图

5、其它
disjoint(Collections<?>c1,Collections<?>c2) 如果两个指定collection中没有相同的元素,则返回true
addAll(Collection<?super T>c,T...a) 一种方便的方式,将所有指定元素添加到指定collection中
Comparator<T>reverseOrder(Comparator<T>cmp)返回一个比较器,它强行反转指定比较器的顺序。如果指定比较器为null,则
此方法等同于reverseOrder(){返回一个比较器,它对实现 Comparable接口的对象集合施加了 自然排序的相反}
ackage com.hdc;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class CollectionsDemo {

    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("jack");
        list.add("tom");
        list.add("lily");
        
        //1、排序方法
//      Collections.reverse(list);   //结果是:lily、jack、tom;
//      Collections.shuffle(list);   //结果是:随机排序的
//      Collections.sort(list);      //结果是:自然排序:jack、lily、tom
//      Collections.sort(list,c);    //结果是:按照指定的比较器排序Comparator c
//      Collections.swap(list, 0, 2);//结果是:lily、tom、jack  {都是对原list的操作}
//      Collections.rotate(list, 1); //结果是:lily、jack、tom  {是将lsit的每个元素右移一位}
        
        
        //2、查找和替换方法
//      System.out.println(Collections.binarySearch(list, "tom")); //结果是:1
//      System.out.println(Collections.max(list)); //结果是:tom
//      System.out.println(Collections.min(list)); //结果是:jack
//      Collections.fill(list, "jerry"); //结果是:jerry, jerry, jerry
//      System.out.println(Collections.frequency(list, "lily"));
//      Collections.replaceAll(list, "lily","bin");
        
        
        //3、同步控制
//      List<String> syncList = Collections.synchronizedList(new ArrayList<String>()); //相当于是把new ArrayList<String>()这个list包装了下,编程可同步的新的list
//      Collections.synchronizedCollection(c)
//      Collections.synchronizedMap(m)
//      Collections.synchronizedSortedMap(m)
//      Collections.synchronizedSet(s)
//      Collections.synchronizedSortedSet(s)
        
        
        System.out.println(list);
        
        
        //4、设置不可变得集合
        List<String> emList = Collections.emptyList();
        //emList.add("lily"); //空list是不能添加元素的返回错误:UnsupportedOperationException
        
        
        //5、其它
        Collections.sort(list,Collections.reverseOrder()); //先对list进行sort自然排序jack, lily, tom,然后强行反转结果:tom, lily, jack
        System.out.println(list);
        
    }
    
    
    /**
    Collections.emptyList()的使用技巧:
    List<String> li = query();
    这里接收到query()时就不会报错,不会报空指针;因为为空时返回:Collections.emptyList();是有长度的,只不过是为0
    */
    public static List<String> query(){
        List<String> list = null;
        //...
        return Collections.emptyList();
    }
    

}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值