Java中的集合(二)单列集合顶层接口------Collection接口

Collection是一个高度封装的集合接口,继承自Iterable接口,它提供了所有集合要实现的默认方法。由于Iterable封装了Iterator迭代器,因此Collection可以使用Iterator迭代器。 Collection用于表示一组单值对象的集合,这些对象也称为元素。 Collection接口定义了一系列抽象方法,规范了对单值类型的集合的操作标准。

一、Collection子接口或子类

Collection分别有QueueListSet三个子接口,一个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接口的更多相关文章

  1. java中Comparator的用法 -- 实现集合和数组排序

    在java中,如果要对集合对象或数组对象进行排序,需要实现Comparator接口以达到我们想要的目标. 接下来我们模拟下在集合对象中对日期属性进行排序 一.实体类Step package com.l ...

  2. JAVA基础部分复习(二、集合类型)

    对于这些常用的集合,建议还是需要先了解一下底层实现原理,这样在不同的使用场景下才能选择更好的方案. Set介绍以及对比,常用方法: package cn.review.day02; import ja ...

  3. java中的最重要的 集合框架

    java.util这个重要的包包含大量的类和接口,支持很多的功能.例如,java.util具有能产生伪随机数的类,还包括可以管理日期和时间.观察事件.操作位集合.标记字符串.处理格式化数据等的类.ja ...

  4. java基础笔试题二(集合关系)

    知识点:java集合继承关系(Collection,Map) 1.集合框架体系图 2.java的集合层次 来自博客(http://blog.csdn.net/stubbornaccepted/arti ...

  5. java中Collections.sort()方法实现集合排序

    1.Integer/String泛型的List进行排序 List <Integer> integerlist = new ArrayList<Integer>();   //定 ...

  6. Java学习关于集合框架的基础接口--Collection接口

     集合框架(Collection  Framework)是Java最强大的子系统之一,位于java.util 包中.集合框架是一个复杂的接口与和类层次,提供了管理对象组的最新技术.Java集合框架标准 ...

  7. java中封装类(二)

    java中的数字类型包括 Byte,Short,Integer,Long,Float,Double.其中前四个是整数,后两个是浮点数. 在说java中数字类型之前先来看看它们统一的基类Number. ...

  8. java中的ArrayList 、List、LinkedList、Collection关系详解

    一.基础介绍(Set.List.Map) Set(集):集合中的元素不按特定方式排序,并且没有重复对象.他的有些实现类能对集合中的对象按特定方式排序. List(列表):集合中的元素按索引位置排序,可 ...

  9. java中的ArrayList 、List、LinkedList、Collection

    原文地址: http://www.cnblogs.com/liqiu/p/3302607.html 一.基础介绍(Set.List.Map) Set(集):集合中的元素不按特定方式排序,并且没有重复对 ...

随机推荐

  1. 最长递增子序列(Longest increasing subsequence)

    问题定义: 给定一个长度为N的数组A,找出一个最长的单调递增子序列(不要求连续). 这道题共3种解法. 1. 动态规划 动态规划的核心是状态的定义和状态转移方程.定义lis(i),表示前i个数中以A[ ...

  2. spring cloud系列教程第一篇-介绍

    spring cloud系列教程第一篇-介绍 前言: 现在Java招聘中最常见的是会微服务开发,微服务已经在国内火了几年了,而且也成了趋势了.那么,微服务只是指spring boot吗?当然不是了,微 ...

  3. query 线段树 + 区间排序

    https://nanti.jisuanke.com/t/41391 这个题目没有很难想,比较暴力,但是要会算复杂度,不会算复杂度,就会觉得自己的算法会超时,实际上不会. 这个题目就是直接暴力求出每一 ...

  4. FOC 电流采样为什么不准?你忽略了这个细节

    文章目录 1 引言 2 延迟类型及典型时间 3 延迟源详细分析 3.1PWM死区时间插入 3.2 光耦延迟和预驱动器延迟 3.3晶体管开关延迟 3.4其他延迟 4 结语 在电机驱动的FOC控制开发过程 ...

  5. .NET IoC模式依赖反转(DIP)、控制反转(Ioc)、依赖注入(DI)

    依赖倒置原则(DIP) 依赖倒置(Dependency Inversion Principle,缩写DIP)是面向对象六大基本原则之一.他是指一种特定的的解耦形式,使得高层次的模块不依赖低层次的模块的 ...

  6. SVN 分支代码合并到主线

    SVN 分支代码合并到主线 步骤一安装TortoiseSVN 客户端,在本地 checkout主线代码 步骤二:创建branches分支 步骤三.branches修改提交代码 步骤四:分支代码合并到主 ...

  7. Altera特殊管脚的使用

  8. Lottery

    0x01 修改金币到8位,才能买东西 robots.txt中发现.git泄露 下载附件,得到源码 审计api.php 我们传入的值与随机生成的值进行比较, 按照相同的个数,得到不同的钱 if($num ...

  9. 利用python在微信群中签到、抢沙发(适用于任何账号)

    利用python在微信群中签到.抢沙发 注意 程序仅能在电脑上运行,运行时需要保证群界面在最前端且不被移动. 背景 我是一名高中生(2020年),疫情期间,在家上网课,有的老师让我们在班群里签到. 其 ...

  10. Python中range, np.arange, np.linspace的区别

    目录 range np.arange np.linspace range 特点 range()是python内置函数,指定开始值,终值和步长生成等差数列的一维数组 不包含终值 步长只能是整数,生成整数 ...