美文网首页
13 Java集合 - Collections工具类

13 Java集合 - Collections工具类

作者: 王毅巽 | 来源:发表于2018-02-22 21:00 被阅读0次

    13.1 Collections工具类

            Collections是Java提供的操作集合的工具类,可以对集合进行排序、查询和修改,还提供了将集合变为不可变、对集合对象实现同步控制的方法等。

    13.2 排序操作

        Collections提供了如下方法对List集合元素进行排序:

            - static void reverse(List list):反转指定List集合中元素的顺序。

            - static void shuffle(List list):对List集合元素进行随机排序(shuffle方法模拟了“洗牌”动作)。

            - static void sort(List list):根据元素的自然顺序对指定List集合的元素按升序进行排序。

            - static void sort(List list, Comparator c):根据指定Comparator产生的顺序对List集合元素进行排序。

            - static void swap(List list, int i, in j):将指定List集合中的i处元素和j处元素进行交换。

            - static void rotate(List list):当distance为正数时,将list集合的后distance个元素“整体”移到前面;当distance为负数时,将list集合的前distance个元素“整体”移到后面。该方法不会改变集合的长度。

    13.3 查找、替换操作

        Collections提供了如下用于查找、替换集合元素的常用方法:

            - static int binarySearch(List list, Object key):使用二分搜索法搜索指定的List集合,以获得指定对象在List集合中的索引。如果要使该方法可以正常工作,则必须保证List中的元素已经处于有序状态。

            - static Object max(Collection c):根据元素的自然顺序,返回指定集合中的最大元素。

            - static Object max(Collection c, Comparator comp):根据Comparator指定的顺序,返回指定集合中的最大元素。

            - static Object min(Collection c):根据元素的自然顺序,返回指定集合中的最小元素。

            - static Object min(Collection c, Comparator comp):根据Comparator指定的顺序,返回指定集合中的最小元素。

            - static void fill(List list, Object obj):使用指定元素obj替换指定List集合中的所有元素。

            - static int frequency(Collection c, Object o):返指定集合中指定元素的出现次数。

            - static int indexOfSubList(List source, List target):返回子List对象在父List对象中第一次出现的位置索引。如果父List中没有出现这样的子List,则返回-1。

            - static int lastndexOfSubList(List source, List target):返回子List对象在父List对象中最后一次出现的位置索引。如果父List 中没有出现这样的子List,则返回-1。

            - static boolean replaceAll(List list, Objcct oldVal, Object newVal):使用一个新值newVal替换List对象的所有旧值oldVal。

    13.4 同步控制

            Java集合框架中的HashSet、TreeSet、ArrayList、ArrayDeque、LinkedList、HashMap和TreeMap都是线程不安全的。

            Collections工具类提供了synchronizedXxx()方法用于将指定集合包装成线程同步的集合,从而可以解决多线程并发访问集合时的线程安全问题。

    13.5 设置集合不可变

        Collections提供了如下类方法来返回一个不可变的集合:

            - empyXxx0:返回一一个空的、不可变的集合对象,此处的集合可以是List、Set和Map。

            - singletonXxx0:返回一个只包含指定对象(只有一个或一项元素)的、不可变的集合对象,此处的集合可以是List和Map。

            - unmodifiableXxx():返回指定集合对象的不可变视图,此处的集合可以是List、Set和Map。

            上面三类方法的参数是原有的集合对象,返回值是该集合的只读版本。

            Set使用singleton()方法返回不可变对象,参数可以为数值、字符串等类型,不必为一个集合。

    相关文章

      网友评论

          本文标题:13 Java集合 - Collections工具类

          本文链接:https://www.haomeiwen.com/subject/hcgztftx.html