Collections类简介

java.utils.Collections 是集合工具类,用来对集合进行操作。此类完全由在 collection 上进行操作或返回 collection 的静态方法组成。

常用方法

  • public static boolean addAll(Collection c, T... elements) :往集合中添加一些元素。
  • public static void shuffle(List list) 打乱顺序 :打乱集合顺序。

代码举例

package demo03Collections;

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

public class Demo01Collections {
    public static void main(String[] args) {
        //定义测试用的集合
        ArrayList<Integer> arrayList = new ArrayList<>();
        //addAll(Collection<T> c, T... elements) :往集合中添加一些元素。
        Collections.addAll(arrayList, 1, 2, 3, 4, 5);
        //查看集合中的元素顺序
        System.out.println(arrayList);//[1, 2, 3, 4, 5]
        //shuffle(List<?> list) 打乱顺序 :打乱集合顺序。
        Collections.shuffle(arrayList);
        //查看集合中的元素顺序
        System.out.println(arrayList);//[5, 1, 4, 3, 2]

    }
}

集合排序

  • public static void sort(List list) :将集合中元素按照默认规则排序。默认规则就是升序

代码举例

package demo03Collections;

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

public class Demo02Collections {
    public static void main(String[] args) {
        //定义测试用的集合
        ArrayList<Integer> arrayList = new ArrayList<>();
        //addAll(Collection<T> c, T... elements) :往集合中添加一些元素。
        Collections.addAll(arrayList, 1, 3, 2, 5, 4);
        System.out.println(arrayList);//[1, 3, 2, 5, 4]
        //sort(List list) :将集合中元素按照默认规则排序。默认规则就是升序。
        Collections.sort(arrayList);
        System.out.println(arrayList);//[1, 2, 3, 4, 5]
    }
}

自定义类型进行排序

排序,简单的说就是两个对象之间比较大小,那么在JAVA中提供了两种比较实现的方式,一种是比较死板的采用 java.lang.Comparable 接口去实现,一种是灵活的当我需要做排序的时候在去选择的java.util.Comparator 接口完成。
  • 方式1: public static void sort(List list ) :实现Comparable,重写接口中的方法compareTo定义排序的规则。 Comparable接口的排序规则:自己(this)-参数:升序
    @Override
    public int compareTo(Student o) {
        //自定义比较的规则,比较两个人的年龄(this,参数Student)
        //return this.getAge() - o.getAge();//年龄升序排序
        return this.getAge() - o.getAge();
    }
}
  • 方式2: public static void sort(List list,Comparator ) :将集合中元素按照指定规则排序。Comparator这个接口,位于位于java.util包下,排序是comparator能实现的功能之一,该接口代表一个比较器,比 较器具有可比性!顾名思义就是做排序的,通俗地讲需要比较两个对象谁排在前谁排在后,那么比较的方法就是: public int compare(String o1, String o2) :比较其两个参数的顺序。 两个对象比较的结果有三种:大于,等于,小于。如果要按照升序排序, 则o1 小于o2,返回(负数),相等返回0,01大于02返回(正数)如果要按照 降序排序 则o1 小于o2,返回(正数),相等返回0,01大于02返回(负数)
ollections.sort(list, new Comparator<Student>() {
@Override
    public int compare(Student o1, Student o2) {
    // 年龄降序
    int result = o2.getAge()‐o1.getAge();//年龄降序
    if(result==0){//第一个规则判断完了 下一个规则 姓名的首字母 升序
        result = o1.getName().charAt(0)‐o2.getName().charAt(0);
        }
return result;
    }
});

简述Comparable和Comparator两个接口的区别

  • Comparable:强行对实现它的每个类的对象进行整体排序。这种排序被称为类的自然排序,类的compareTo方法 被称为它的自然比较方法。只能在类中实现compareTo()一次,不能经常修改类的代码实现自己想要的排序。实现 此接口的对象列表(和数组)可以通过Collections.sort(和Arrays.sort)进行自动排序,对象可以用作有序映射中 的键或有序集合中的元素,无需指定比较器。

  • Comparator强行对某个对象进行整体排序。可以将Comparator 传递给sort方法(如Collections.sort或 Arrays.sort),从而允许在排序顺序上实现精确控制。还可以使用Comparator来控制某些数据结构(如有序set或 有序映射)的顺序,或者为那些没有自然顺序的对象collection提供排序。

简而言之:
Comparator和Comparable的区别

  • Comparable:自己(this)和别人(参数)比较,自己需要实现Comparable接口,重写比较的规则compareTo方法
  • Comparator:相当于找一个第三方的裁判,比较两个

java之集合工具类Collections的更多相关文章

  1. java的集合工具类Collections

    集合框架的工具类. Collections:集合框架的工具类.里面定义的都是静态方法. Collections和Collection有什么区别? Collection是集合框架中的一个顶层接口,它里面 ...

  2. Java:集合工具类-Collections

    Java.util.Collections 集合框架工具类Collections,其方法都是静态的,本身没有构造函数. 常见方法: static <T extends Comparable< ...

  3. Java从零开始学二十四(集合工具类Collections)

    一.Collections简介 在集合的应用开发中,集合的若干接口和若干个子类是最最常使用的,但是在JDK中提供了一种集合操作的工具类 —— Collections,可以直接通过此类方便的操作集合 二 ...

  4. Java笔记(二十四)……集合工具类Collections&Arrays

    Collections 集合框架的工具类,方法全部为静态 Collections与Collection的区别 Collection是集合框架的一个顶层接口,里面定义了单列集合的共性方法 Collect ...

  5. Java常用类(五)之集合工具类Collections

    前言 Java提供了一个操作Set.List和Map等集合的工具类:Collections,该工具类提供了大量方法对集合进行排序.查询和修改等操作, 还提供了将集合对象置为不可变.对集合对象实现同步控 ...

  6. 吴裕雄--天生自然java开发常用类库学习笔记:集合工具类Collections

    import java.util.Collections ; import java.util.List ; import java.util.Set ; public class Collectio ...

  7. [黑马程序员] 集合框架2——Map系 & 集合工具类(Collections、Arrays)

    ---------------------- ASP.Net+Android+IO开发..Net培训.期待与您交流! ---------------------- 0. 集合框架按其所实现的接口, 大 ...

  8. Java 集合工具类---------- Collections类

  9. [Google Guava] 2.3-强大的集合工具类:java.util.Collections中未包含的集合工具

    原文链接 译文链接 译者:沈义扬,校对:丁一 尚未完成: Queues, Tables工具类 任何对JDK集合框架有经验的程序员都熟悉和喜欢java.util.Collections包含的工具方法.G ...

随机推荐

  1. PC端、移动端页面适配方案

    前言 页面自适应PC端.移动端大体上可以分为两种: 1.在同一个页面进行自适应布局,通常使用CSS3 @media 媒体查询器实现 2.两套页面,在后端进行统一适配,根据不同的浏览器UA返回对应的页面 ...

  2. Javascript 垃圾回收方法

    Javascript 垃圾回收方法 标记清除(mark and sweep) 这是 JavaScript 最常见的垃圾回收方式,当变量进入执行环境的时候,比如函数中声明一个变量,垃圾回收器将其标记为& ...

  3. 从零开始—Socket系统调用和多态封装

    1 重新搭建实验环境 前面都是用实验楼环境做的实验,偷的懒总是要还的,这一次重装环境前后花了十几个小时,踩了无数的坑. 1.1 Ubuntu和LINUX内核的区别 Ubuntu是基于LINUX内核编写 ...

  4. idea 几个常用的设置

    一.主题的背景

  5. 2019年全国高校计算机能力挑战赛初赛java语言解答

    1:题目1 16.某星球存在两种生物,A种生物有1个头6条腿,B种生物有3个头4条腿.来自地球的太空船刚刚在该星球降落,突然发现一大群这两种生物组成的队伍,由于时间紧,只数了头的数量和腿的数量,请帮助 ...

  6. Python面向对象-获取对象信息type()、isinstance()、dir()

    type() type()函数用于判断对象类型: >>> type(11) <class 'int'> >>> type('abc') <clas ...

  7. 敏捷开发--洞察敏捷模型,从PO的角度看敏捷产品管理

    转自本人运营的公众号“ 携程技术中心PMO”(ID:cso_pmo)       经常有人抱怨的一个问题:敏捷会让团队自组织,要求团队能“一方有难,八方支援”,但是为什么总感觉自己团队虽然实践了敏捷, ...

  8. java月考题JSD1908第二次月考(含答案和解析)

    考试 .container { clear: both; margin: 0 auto; text-align: left; /*width: 1200px;*/ } .container:after ...

  9. dataguard ORA-12514: TNS:listener does not currently know of service requested in connect descriptor

    错误的意思是listener 不知道连接解析器中的请求服务,这里要说静态监听和动态监听了动态注册是在instance启动的时候PMON进程根据init.ora中的instance_name,servi ...

  10. leetcode菜鸡斗智斗勇系列(2)--- 把一个ipv4地址转换成一串数字

    1.原题: https://leetcode.com/problems/defanging-an-ip-address/ 这道题本身很简单, Given a valid (IPv4) IP addre ...