Java 中Collections工具类的使用

简介: Java 中Collections工具类的使用

前言:

Collections是一个操作Set,list和Map集合的工具类

Collections工具类中常用的方法,下面我通过代码演示

@Test
    public void test1() {
        List list = new ArrayList();
        list.add(12);
        list.add(19);
        list.add(23);
        list.add(20);
        list.add(15);
        //1.reverse(list):反转list中元素的顺序
        System.out.println(list);
       /* Collections.reverse(list);
        System.out.println(list);*/
        //2.shuffle(list):对list集合元素进行随机排序
       /* Collections.shuffle(list);
        System.out.println(list);*/
        //3.sort(list):根据元素的自然排序对指定list集合按升序排序
        Collections.sort(list);
        System.out.println(list);
        //4.swap(list,int,int):将指定list集合的i处元素和j处元素进行交换
        Collections.swap(list,2,4);
        System.out.println(list);
        //5.int frequency(Collection,object):返回指定集合中指定元素的出现次数
        int frequency = Collections.frequency(list,12);
        System.out.println(frequency);
    }
    @Test
    public void test2(){
        List list = new ArrayList();
        list.add(12);
        list.add(19);
        list.add(23);
        list.add(20);
        list.add(15);
        //6.void copy(list dest,list src):将src中的内容复制到dest中
        List dest = Arrays.asList(new Object[list.size()]);
        Collections.copy(dest,list);
        System.out.println(dest);
    }

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

//返回的这个list1就是线程安全的
        List list1 = Collections.synchronizedList(list);

Collections额外的其他方法如下

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) {
                if (!(o1 instanceof String && o2 instanceof String)) {
                    System.out.println("类型不正确!");
                    return 0; //表示不比了,返回0就行了
                }
                return ((String) o1).length() - ((String) o2).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) {
                if (!(o1 instanceof String && o2 instanceof String)) {
                    System.out.println("类型不正确!");
                    return 0;
                }
                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中
        //为了完成一个完整的拷贝,我们需要先给dest赋值,大小和list.size() 一样
        //拷贝
        ArrayList dest = new ArrayList();
        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);
    }
}

输出结果如下

list=[milan, king, smith, tom]
自然排序后
list=[king, milan, smith, tom]
字符串长度从小到大排序=[tom, king, milan, smith]
交换后的情况
list=[king, tom, milan, smith]
自然顺序最大元素=tom
长度最大的元素为:milan
tom出现的次数:1
dest=[king, tom, milan, smith]
list替换后:[king, 汤姆, milan, smith]


目录
相关文章
|
16天前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
40 17
|
1月前
|
算法 搜索推荐 Java
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
这篇文章介绍了如何使用Java后端技术,结合Graphics2D和Echarts等工具,生成包含个性化信息和图表的海报,并提供了详细的代码实现和GitHub项目链接。
105 0
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
|
1月前
|
Java
Java 些许公共工具类
Java 些许公共工具类
15 1
|
3月前
|
缓存 前端开发 Java
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
【8月更文挑战第10天】java基础巩固,工具类的封装
27 1
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
|
3月前
|
Java
Java应用结构规范问题之在UnitConvertUtils工具类将千米转换为米的问题如何解决
Java应用结构规范问题之在UnitConvertUtils工具类将千米转换为米的问题如何解决
|
3月前
|
存储 设计模式 安全
Java GenericObjectPool 对象池化技术--SpringBoot sftp 连接池工具类
Java GenericObjectPool 对象池化技术--SpringBoot sftp 连接池工具类
52 0
|
4月前
|
设计模式 存储 安全
Java面试题:设计一个线程安全的单例类并解释其内存占用情况?使用Java多线程工具类实现一个高效的线程池,并解释其背后的原理。结合观察者模式与Java并发框架,设计一个可扩展的事件处理系统
Java面试题:设计一个线程安全的单例类并解释其内存占用情况?使用Java多线程工具类实现一个高效的线程池,并解释其背后的原理。结合观察者模式与Java并发框架,设计一个可扩展的事件处理系统
62 1
|
4月前
|
安全 Java 开发者
Java中的并发工具类与线程安全实现
Java中的并发工具类与线程安全实现
|
4月前
|
设计模式 缓存 算法
编写高效的Java工具类:实用技巧与设计模式
编写高效的Java工具类:实用技巧与设计模式
|
4月前
|
并行计算 Java API
Java中的并发工具类详解
Java中的并发工具类详解