【JAVA学习笔记】 56 - 开发中如何选择集合实现类,以及Collection工具类

项目代码

https://github.com/yinhai1114/Java_Learning_Code/blob/main/IDEA_Chapter14/src/com/yinhai/Collections_.java

在开发中,选择什么集合实现类,主要取决于业务操作特点,然后根据集合实现类特性进行

选择,分析如下:

0.先判断存储的类型(一组对象[单列]或一组键值对[双列])

1.一组对象: Collection接口(单列)

1)允许重复: List

增删多: LinkedList [底层维护了一一个双向链表]

改查多: ArrayList [底层维护Object类型的可变数组]

2)不允许重复: Set

无序: HashSet [底层是HashMap,维护了一个哈希表即(数组+链表+红黑树)]

排序: TreeSet

插入和取出顺序一致: LinkedHashSet , 维护数组+双向链表

2.一组键值对: Map(双列)

键无序: HashMap [底层是:哈希表jdk7: 数组+链表,jdk8: 数组+链表+红黑树]

键排序: TreeMap

键插入和取出顺序一致: LinkedHashMap

读取文件Properties

Collections工具类

一、Collections工具类介绍

1.Collections是一个操作Set、List 和Map等集合的工具类

2.Collections中提供了一系列静态的方法对集合元素进行排序、查询和修改等操作

1.排序操作: (均为static方法)

  1. reverse(List):反转List中元素的顺序

  2. shuffle(List):对List集合元素进行随机排序

  3. sort(List):根据元素的自然顺序对指定List 集合元素按升序排序

  4. sort(List, Comparator): 根据指定的Comparator产生的顺序对List集合元素排序

  5. swap(List, int, int): 将指定list集合中的i处元素和j处元素进行交换

2.查找、替换

  1. Object max(Collection):根据元素的自然顺序,返回给定集合中的最大元素

  2. Object max(Collection, Comparator): 根据Comparator指定的顺序,返回给定集合中的最大元素

  3. Object min(Collection)

  4. Object min(Collection, Comparator)

  5. int frequency(Collection, Object): 返回指定集合中指定元素的出现次数

  6. void copy(List dest,List src):将src中的内容复制到dest中

  7. boolean replaceAll(List list, Object oldVal, Object newVal):使用新值替换List 对象的所有旧值

java 复制代码
public class Collections_ {
    public static void main(String[] args) {

        //创建ArrayList 集合,用于测试.
        List list = new ArrayList();
        list.add("tom");
        list.add("smith");
        list.add("king");
        list.add("milan");
        list.add("tom");


        // reverse(List):反转 List 中元素的顺序
        Collections.reverse(list);
        System.out.println("list=" + list);

        // shuffle(List):对 List 集合元素进行随机排序

        for (int i = 0; i < 5; i++) {
            Collections.shuffle(list);
            System.out.println("list=" + list);
        }


        // sort(List):根据元素的自然顺序对指定 List 集合元素按升序排序
        Collections.sort(list);
        System.out.println("自然排序后");
        System.out.println("list=" + list);

        //sort(List,Comparator):根据指定的 Comparator 产生的顺序对 List 集合元素进行排序
        //我们希望按照 字符串的长度大小排序
        Collections.sort(list, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                //可以加入校验代码.
                return ((String) o2).length() - ((String) o1).length();
            }
        });
        System.out.println("字符串长度大小排序=" + list);

        // swap(List,int, int):将指定 list 集合中的 i 处元素和 j 处元素进行交换
        //比如
        Collections.swap(list, 0, 1);
        System.out.println("交换后的情况");
        System.out.println("list=" + list);

        //Object max(Collection):根据元素的自然顺序,返回给定集合中的最大元素
        System.out.println("自然顺序最大元素=" + Collections.max(list));
        //Object max(Collection,Comparator):根据 Comparator 指定的顺序,返回给定集合中的最大元素
        //比如,我们要返回长度最大的元素
        Object maxObject = Collections.max(list, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                return ((String) o1).length() - ((String) o2).length();
            }
        });
        System.out.println("长度最大的元素=" + maxObject);


        //Object min(Collection)
        //Object min(Collection,Comparator)
        //上面的两个方法,参考max即可

        //int frequency(Collection,Object):返回指定集合中指定元素的出现次数
        System.out.println("tom出现的次数=" + Collections.frequency(list, "tom"));

        //void copy(List dest,List src):将src中的内容复制到dest中
        ArrayList dest = new ArrayList();
        //为了完成一个完整拷贝,我们需要先给dest 赋值,大小和list.size()一样
        for (int i = 0; i < list.size(); i++) {
            dest.add("");
        }
        //拷贝
        Collections.copy(dest, list);
        System.out.println("dest=" + dest);

        //boolean replaceAll(List list,Object oldVal,Object newVal):使用新值替换 List 对象的所有旧值
        //如果list中,有tom 就替换成 汤姆
        Collections.replaceAll(list, "tom", "汤姆");
        System.out.println("list替换后=" + list);


    }
}
相关推荐
嘉陵妹妹4 分钟前
深度优先算法学习
学习·算法·深度优先
乖乖是干饭王1 小时前
Linux系统编程中的_GNU_SOURCE宏
linux·运维·c语言·学习·gnu
stein_java1 小时前
springMVC-10验证及国际化
java·spring
weixin_478689761 小时前
C++ 对 C 的兼容性
java·c语言·c++
LUCIAZZZ1 小时前
HikariCP数据库连接池原理解析
java·jvm·数据库·spring·springboot·线程池·连接池
待什么青丝2 小时前
【TMS570LC4357】之相关驱动开发学习记录2
c语言·arm开发·驱动开发·单片机·学习
sky_ph2 小时前
JAVA-GC浅析(二)G1(Garbage First)回收器
java·后端
行云流水剑2 小时前
【学习记录】如何使用 Python 提取 PDF 文件中的内容
python·学习·pdf
IDRSolutions_CN2 小时前
PDF 转 HTML5 —— HTML5 填充图形不支持 Even-Odd 奇偶规则?(第二部分)
java·经验分享·pdf·软件工程·团队开发
hello早上好2 小时前
Spring不同类型的ApplicationContext的创建方式
java·后端·架构