13 Java集合 - Collections工具类

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()方法返回不可变对象,参数可以为数值、字符串等类型,不必为一个集合。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,760评论 18 399
  • 第十天 权限修饰符 public protected default private 同一类 true true ...
    炙冰阅读 551评论 0 1
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,288评论 0 16
  • 一个女孩儿,能对任何事情都有一个不焦不躁平淡的态度和一颗耐得住寂寞的心,本身就是一种太具吸引力气质和一种骨...
    W丽平阅读 1,229评论 0 2
  • 人类及所有生命体,都有着或长或短的一生。在这一生里,无论长短,无论平凡或轰烈,都得经历各种各样的选择,是去或...
    你该是一棵树阅读 170评论 0 1