接口Collection

public interface Collection<E>定义了所有单列集合中共性的方法,所有的单列集合都可以使用共性方法。

Collection的常用子接口有:

  1. public interface List<E> extends Collection<E>

    1. 特点:『有序』、『允许存储重复元素』、『有索引』(可以使用普通的for循环)
    2. 常用实现类有:
      • java.util.ArrayList
      • java.util.LinkedList
  2. public interface Set<E> extends Collection<E>

    1. 特点: 『 无序 』 、 『 不可存储重复元素 』 (不可使用普通for循环)

      更正式地说,集合中不包含e1和e2这样的一对元素,满足e1.equals(e2)

    2. 常用实现类:java.util.HashSet

Collection接口中定义的一些抽象方法:

  1. int size(): 返回此集合中元素的数量
  2. boolean isEmpty(): 如果该集合不包含元素,则返回true,否则返回false
  3. boolean contains(Object o): 如果该集合包含指定的元素,则返回true,否则返回false
  4. Iterator<E> iterator(): 返回该集合中元素的迭代器, 不能保证元素返回的顺序
  5. Object[] toArray(): 返回一个包含此集合中所有元素的数组
  6. boolean add(E e):往集合中添加元素,成功返回true,失败返回false
  7. boolean remove(Object o):从集合中删除指定元素,如果存在的话,返回true,
  8. boolean containsAll(Collection<?> c): 如果该集合包含指定集合中的所有元素,则返回true。
  9. boolean addAll(Collection<? extends E> c):将指定集合中的所有元素添加到此集合
  10. boolean removeAll(Collection<?> c): 删除指定集合中包含的该集合的所有元素
  11. void clear(): 从集合中删除所有元素

类Collections

public class Collections extends Object该【类】专门由操作或返回集合的静态方法组成。

Collections中定义的静态常量

public static final List EMPTY_LIST = new EmptyList<>();
public static final Map EMPTY_MAP = new EmptyMap<>();
public static final Set EMPTY_SET = new EmptySet<>();

Collections中定义的静态方法

代码中的注释中被【】括起来的内容是对应的输出结果。

import java.util.ArrayList;
import java.util.Collections; public class CLASS1 {
public static void main(String[] args) {
ArrayList<Integer> arr = new ArrayList<>(); // ===========addAll(Collection c, T... elements)===========
Collections.addAll(arr, 3, 1, 5, 4, 2); // 往指定集合中添加元素,第二个参数是一个可变参数
System.out.println(arr); // 【[3, 1, 5, 4, 2]】 // ===========sort(List)===========
Collections.sort(arr); // 默认升序排列
System.out.println(arr); // 【[1, 2, 3, 4, 5]】 // ===========sort(List, Comparator)=========
Collections.sort(arr, ((o1, o2) -> o2 - o1)); // 通过实现Comparator接口实现降序排列
System.out.println(arr); // 【[5, 4, 3, 2, 1]】 // ===========binarySearch(List, key)===========
int ind = Collections.binarySearch(arr, 2);
System.out.println(ind); // arr目前是降序排列,而二分查找默认是按照升序排列进行的,所以找不到,返回【-1】 // ===========binarySearch(List, key, Comparator)===========
ind = Collections.binarySearch(arr, 2, (o1, o2) -> o2 - o1);
System.out.println(ind); // 降序排列使用二分查找,返回索引值【3】,索引从0开始 // ===========reverse(List)===========
Collections.reverse(arr); // 反转List
System.out.println(arr); // 【[1, 2, 3, 4, 5]】 // ===========max(List) & min(List)===========
System.out.println(Collections.max(arr)); // 【5】
System.out.println(Collections.min(arr)); // 【1】 // ===========shuffle(List)===========
Collections.shuffle(arr); // 打乱集合中的元素排列顺序
System.out.println((arr)); // 【[2, 4, 3, 1, 5]】
}
}

『Java』Collection接口 Collections类的更多相关文章

  1. JAVA中Collection接口和Map接口的主要实现类

    Collection接口 Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements).一些Collection允许相同的元素 ...

  2. Java基础之Comparable接口, Collections类,Iterator接口,泛型(Generic)

    一.Comparable接口, Collections类 List的常用算法: sort(List); 排序,如果需要对自定义的类进行排序, 那就必须要让其实现Comparable接口, 实现比较两个 ...

  3. java类库 collection与collections (转)

    http://www.cnblogs.com/dashi/p/3597937.html Java中Collection和Collections的区别 1.java.util.Collection 是一 ...

  4. Java基础——collection接口

    一.Collection接口的定义 public interfaceCollection<E>extends iterable<E>  从接口的定义中可以发现,此接口使用了泛型 ...

  5. 『Java』接口的使用方法

    以下三个文件存在于同一个包下: 定义接口Dome_Interface.java: package cn.xxmmqg.Interface; // 接口不能直接使用,必须有一个"实现类&quo ...

  6. Java中Collection和Collections的区别(引用自:http://www.cnblogs.com/dashi/p/3597937.html)

      1.java.util.Collection 是一个集合接口(集合类的一个顶级接口).它提供了对集合对象进行基本操作的通用接口方法.Collection接口在Java 类库中有很多具体的实现.Co ...

  7. Java 集合-Collection接口和迭代器的实现

    2017-10-30 00:30:48 Collection接口 Collection 层次结构 中的根接口.Collection 表示一组对象,这些对象也称为 collection 的元素.一些 c ...

  8. Java中Collection和Collections的区别(转载)

    转载来源:http://www.cnblogs.com/dashi/p/3597937.html 1.java.util.Collection 是一个集合接口(集合类的一个顶级接口).它提供了对集合对 ...

  9. 谈谈Java的Collection接口

    目录 谈谈Collection 前言 Collection 方法 1.boolean add(E) 2.void clear() 3.boolean contains(Object o) 4.bool ...

随机推荐

  1. 8、inotify和resync的优缺点

    只有对外提供访问的服务需要有端口号,本地服务无端口号: 8.1.inotify的优缺点: 1.优点: 监控文件系统事件变化,通过同步工具实现实时的数据同步 2.缺点: 并发如果大于200个文件(10- ...

  2. GDI+中发生一般性错误的解决办法(转载)

    今天在开发.net引用程序中,需要System.Drawing.Image.Save 创建图片,debug的时候程序一切正常,可是发布到IIS后缺提示出现"GDI+中发生一般性错误" ...

  3. Docker环境RabbitMq配置SSL

    RabbitMQ要对外提供服务,考虑到安全性,配置SSL进行访问,ssl端口5671,内部仍然使用5672进行访问,两者同时兼容. 安装环境 CentOS 7.5 Docker 1.13.1 Git ...

  4. Defense:MS08067漏洞攻防渗透实验

    实验环境 Windows XP SP3 IP:172.16.211.129 百度网盘:https://pan.baidu.com/s/1dbBGdkM6aDzXcKajV47zBw     靶机环境 ...

  5. shell运维习题训练

    注:初学shell,以下为本人自己写的答案,如果有更好的,请指教! 1. 求2个数之和: 2. 计算1-100的和 3. 将一目录下所有的文件的扩展名改为bak 4.编译并执行当前目录下的所有.c文件 ...

  6. 华为高级研究员谢凌曦:下一代AI将走向何方?盘古大模型探路之旅

    摘要:为了更深入理解千亿参数的盘古大模型,华为云社区采访到了华为云EI盘古团队高级研究员谢凌曦.谢博士以非常通俗的方式为我们娓娓道来了盘古大模型研发的"前世今生",以及它背后的艰难 ...

  7. maevn的nexus私库搭建

    使用nexus搭建maven仓库(本地私服) 前言:我们在使用maven的时候,对于项目所依赖的jar包,maven默认会在中央仓库下载jar包,到本地的磁盘目录(如果没有配置则是用户目录下/.m2/ ...

  8. kong配置upstream实现简单的负载均衡

    目录 通过konga实现 1. 配置upstream 2. 配置Service发布 3. 配置Route,匹配规则 4. 验证结果 通过 Kong Admin API实现 1. 配置upstream ...

  9. 小 W 离职了

    今天这篇是架构师大刘的系列故事 小W要离职了,大刘并没有挽留,甚至有点庆幸. 小W离职的原因比较简单,这次升职加薪,大刘提拔了和他同期进来,并且工作年限和他差不多的小L,而小W则是原地没动,薪水也没有 ...

  10. 单细胞分析实录(17): 非负矩阵分解(NMF)代码演示

    本次演示使用的数据来自2017年发表于Cell的头颈鳞癌单细胞文章:Single-Cell Transcriptomic Analysis of Primary and Metastatic Tumo ...