Java中的集合(二)单列集合顶层接口------Collection接口
Java中的集合(二)单列集合顶层接口------Collection接口
Collection是一个高度封装的集合接口,继承自Iterable接口,它提供了所有集合要实现的默认方法。由于Iterable封装了Iterator迭代器,因此Collection可以使用Iterator迭代器。 Collection用于表示一组单值对象的集合,这些对象也称为元素。 Collection接口定义了一系列抽象方法,规范了对单值类型的集合的操作标准。
一、Collection子接口或子类
Collection分别有Queue、List及Set三个子接口,一个AbstractCollection抽象类。由于Collection接口没有可用的实现类,所以在使用Collection时,必须使用它的子类或子接口。

二、Collection常用方法

三、Collection增加和移除元素
String str = "hello world";
Collection collection = new ArrayList();
collection.add("hello"); boolean isChange = collection.add(str);
boolean isWas = collection.remove(str); Iterator ite = collection.iterator(); while(ite.hasNext()) {
System.out.println(ite.next());
}
(一)、添加元素
1、使用add(E e)方法向Collection中添加元素,如果Collection的结构改变了,也就是元素添加成功了,该方法就会返回“true“,否则返回“false”;
2、如果Collection引用的是List接口或List的子类,调用add方法时,如果已经存储有该元素,那么集合中就有两个该元素(因为List接口是有序可重复的);
3、如果Collection引用的是Set接口或Set的子类,调用add方法时,如果已经存储有该元素,那么不会重复添加,保证集合中只有一个该元素(因为Set接口是无序不可重复的)。
add(E e)和addAll(Collection<? extends E> c)的区别:
当传递给方法的参数是一个集合对象时,
1、add方法添加的集合对象本身;
2、addAll方法添加的是集合对象当中的所有元素,集合对象本身不会被添加。
(二)、移除元素
使用remove(Object obj)方法移除Collection中的元素,如果Collection中存在该元素,执行完成后返回“true”,否则返回“false”。
使用removeAll(Collection<?> c)方法移除通过参数传递过来的Collection中的所有元素如果传递过来的Collection中某些元素在目标Collection中不存在,这些元素将会忽略。
retainAll(Collection<?> c)方法正好和removeAll(Collection<?> c)方法相反。不是移除所有给定参数Collection中元素,而是保留保留这些元素,移除其他的元素。
记住,只有目标Collection中已经存在了这些元素,这些元素才可以保留。在参数Collection中存在而目标Collection中不存在的元素,将不会被新增到目标Collection。它们将被忽略。
四、检测一个Collection是否包含一个确定的元素
Collection接口中有两个方法来确定Collection中是否包含一个或多个元素,这两个方法分别为:contains(Object o)和containsAll(Collection<?> c)。
1、contains(Object o):如果这个Collection含有这个元素,contains()方法将返回true,反之,返回“false”。
2、containsAll(Collection<?> c):如果这个Collection含有参数Collection中的所有元素,containsAll()方法将返回true,反之,返回“false”。
五、Collection的大小
Collection接口可以调用size()方法返回Collection的大小。
六、Collection的遍历
1、由于Collection是Iterable接口的,Iterable有封装了Iterator迭代器,所有Collection可以使用迭代器遍历元素;
2、可以使用foreach循环遍历Collection元素。
七、AbstractCollection抽象类
AbstractCollection是Collection接口的一个直接实现类,Collection接口下的子类大多继承自AbstractCollection,比如List的实现类,Set的实现类。除了iterator()和size()方法,它提供了一些其他接口的默认实现,其他集合类可以继承此类来复用。
AbstractCollection除了提供一些其他接口的默认实现,还定义了两个抽象方法,留给子类实现:
1、public abstract Iterator<E> iterator();
2、public abstract int size();
子类必须实现上面两个抽象方法。另外,AbstractCollection默认不支持添加元素的操作,直接调用add(E e)方法会报UnsupportedOperationException错误。
Java中的集合(二)单列集合顶层接口------Collection接口的更多相关文章
- java中Comparator的用法 -- 实现集合和数组排序
在java中,如果要对集合对象或数组对象进行排序,需要实现Comparator接口以达到我们想要的目标. 接下来我们模拟下在集合对象中对日期属性进行排序 一.实体类Step package com.l ...
- JAVA基础部分复习(二、集合类型)
对于这些常用的集合,建议还是需要先了解一下底层实现原理,这样在不同的使用场景下才能选择更好的方案. Set介绍以及对比,常用方法: package cn.review.day02; import ja ...
- java中的最重要的 集合框架
java.util这个重要的包包含大量的类和接口,支持很多的功能.例如,java.util具有能产生伪随机数的类,还包括可以管理日期和时间.观察事件.操作位集合.标记字符串.处理格式化数据等的类.ja ...
- java基础笔试题二(集合关系)
知识点:java集合继承关系(Collection,Map) 1.集合框架体系图 2.java的集合层次 来自博客(http://blog.csdn.net/stubbornaccepted/arti ...
- java中Collections.sort()方法实现集合排序
1.Integer/String泛型的List进行排序 List <Integer> integerlist = new ArrayList<Integer>(); //定 ...
- Java学习关于集合框架的基础接口--Collection接口
集合框架(Collection Framework)是Java最强大的子系统之一,位于java.util 包中.集合框架是一个复杂的接口与和类层次,提供了管理对象组的最新技术.Java集合框架标准 ...
- java中封装类(二)
java中的数字类型包括 Byte,Short,Integer,Long,Float,Double.其中前四个是整数,后两个是浮点数. 在说java中数字类型之前先来看看它们统一的基类Number. ...
- java中的ArrayList 、List、LinkedList、Collection关系详解
一.基础介绍(Set.List.Map) Set(集):集合中的元素不按特定方式排序,并且没有重复对象.他的有些实现类能对集合中的对象按特定方式排序. List(列表):集合中的元素按索引位置排序,可 ...
- java中的ArrayList 、List、LinkedList、Collection
原文地址: http://www.cnblogs.com/liqiu/p/3302607.html 一.基础介绍(Set.List.Map) Set(集):集合中的元素不按特定方式排序,并且没有重复对 ...
随机推荐
- 积性函数初步(欧拉$\varphi$函数)
updata on 2020.4.3 添加了欧拉\(\varphi\)函数为积性函数的证明和它的计算方式 1.积性函数 设\(f(n)\)为定义在正整数上的函数,若\(f(1)=1\),且对于任意正整 ...
- P2002 消息扩散(缩点)
描述:https://www.luogu.com.cn/problem/P2002 有n个城市,中间有单向道路连接,消息会沿着道路扩散,现在给出n个城市及其之间的道路,问至少需要在几个城市发布消息才能 ...
- 2020牛客寒假算法基础集训营1 J题可以回顾回顾
2020牛客寒假算法基础集训营1 这套题整体来说还是很简单的. A.honoka和格点三角形 这个题目不是很难,不过要考虑周全,面积是1,那么底边的长度可以是1也可以是2, 注意底边1和2会有重复的, ...
- C. Helga Hufflepuff's Cup 树形dp 难
C. Helga Hufflepuff's Cup 这个题目我感觉挺难的,想了好久也写了很久,还是没有写出来. dp[i][j][k] 代表以 i 为根的子树中共选择了 j 个特殊颜色,且当前节点 i ...
- jQuery的相关尺寸获取 - 学习笔记
获取元素相对于文档的偏移量 获取当前元素相对于父级元素的偏移量 获取文档滚动距离 获取元素的宽度和高度 设置元素的宽度和高度 获取可视区域的宽度和高度 获取文档的宽度和高度 获取元素相对于文档的偏移量 ...
- Spring Cloud学习 之 Spring Cloud Ribbon(负载均衡策略)
文章目录 AbstractLoadBalancerRule: RandomRule: RoundRobinRule: RetryRule: WeightedResponseTimeRule: 定时任务 ...
- Spring Cloud 学习 之 Spring Cloud Eureka(架构)
Spring Boot版本:2.1.4.RELEASE Spring Cloud版本:Greenwich.SR1 文章目录 Eureka服务治理基础架构的三个核心要素: 服务治理机制: 服务提供者: ...
- Day_09【常用API】扩展案例2_测试小字符串在大字符串中出现的次数
分析以下需求,并用代码实现 1.键盘录入一个大字符串,再录入一个小字符串 2.统计小字符串在大字符串中出现的次数 3.代码运行打印格式: 请输入大字符串: woaiheima,heimabutongy ...
- Linux Kernel Makefiles Kbuild en
来自Linux kernel docs,顺便整理了一下排版 Linux Kernel Makefiles This document describes the Linux kernel Makefi ...
- [hdu4599]期望DP
思路:容易知道G(x)=6x,H(x)=6F(x).此题的关键是求出F(x)的通项,要求F(x)的通项,先建立递推式:F(x)=1/6 * (F(x-1)+1) + 5/6 * (F(x-1)+1+F ...