JAVA集合框架 - Collection
collection大致介绍
Collection是集合层次结构中的根接口。
集合表示一组对象。有些集合允许重复元素,有些则不允许。有些是有序的,有些是无序的。
JDK没有提供此接口的任何直接实现:它提供了更具体的子接口(如Set和List)的实现。
这个接口通常用于在需要最大通用性的地方传递和操作集合 包或多集(可能包含重复元素的无序集合)应该直接实现此接口。
Collection的大致结构体系:

其中常用的有:
List, ArrayList, LinkedList, Vector.
Set, HashSet, TreeSet, LinkedHashList
下文中会挨个看看大致的特性和部分源码.
Collection接口提供的功能:
1.添加:
// 添加一个元素.
boolean add(E e);
// 添加多个元素.
boolean addAll(Collection<? extends E> c);
2.删除:
// 删除一个元素.
boolean remove(Object o);
// 删除多个元素.
boolean removeAll(Collection<?> c);
// 清空集合
void clear();
3.判断:
// 判断是否为空,为空则返回true
boolean isEmpty();
// 判断是否包含元素
boolean contains(Object o);
// 是否全部包含指定元素
boolean containsAll(Collection<?> c);
// 判断是否相等
boolean equals(Object o);
4.获取:
// 继承自Iterable<E>的迭代器, 用于遍历所有元素
Iterator<E> iterator();
// 返回集合的哈希码
int hashCode();
5.长度:
//返回此集合中的元素数目。如果数量超过int最大值就返回int最大值
int size();
6.交集:
// 移除未包含在c中的所有元素.返回值表示是否发生过移除操作
boolean retainAll(Collection<?> c);
7. 转换
// 转换为数组
Object[] toArray();
// 转换为特定类型的数组
<T> T[] toArray(T[] a);
8. 流操作
// 串行流操作
default Stream<E> stream()
// 并行流操作
default Stream<E> parallelStream()
Iterator 大致介绍
Iterator(迭代器),用于以迭代的方式遍历集合.
是一种模式、详细可见迭代器设计模式.
可以使得序列类型的数据结构的遍历行为与被遍历的对象分离,即我们无需关心该序列的底层结构是什么样子的。
只要拿到这个对象,使用迭代器就可以遍历这个对象的内部。
一般是在集合内提供私有的实现方法,用于迭代集合类.
Tterator提供的接口:
// 是否有下一个元素
boolean hasNext();
// 返回迭代中的下一个元素。
E next();
/**
* 从基础集合中移除此迭代器返回的最后一个元素(可选操作)。
* 此方法在每次调用next时只能调用一次。
* 如果没有继承方法,默认会抛出 UnsupportedOperationException("remove") 异常
*/
default void remove()
// 提供函数式编程
default void forEachRemaining(Consumer<? super E> action)
Fail-Fast 机制
概念
fail-fast机制,即快速失败机制,是java集合中的一种错误检测机制。
当在迭代集合的过程中集合的结构发生改变(对集合结构的操作会记录操作次数),就会发生fail-fast,抛出ConcurrentModificationException异常。
在面对并发修改时,迭代器会快速而干净地失败,而不是在将来某个不确定的时间冒任意的、不确定的行为的风险。
fail-fast机制并不保证在不同步的修改下一定抛出异常,它只是尽最大努力去发现并抛出异常,迭代器的快速故障行为应该只用于检测bug。
源码中 如何实现的
以为迭代ArrayList为例:
fail-fast的实现依赖于ArrayList<E>的父类AbstractList<E>,在AbstractList<E>中,有一个protected transient int modCount = 0;的成员变量来记录集合被操作的次数.
在ArrayList中, add,remove,replace等操作都会有modCount++来记录集合的被操作次数.
在进行迭代的过程中调用每个方法前对modCount和开始迭代时记录的expectedModCount进行比对. 如果不一样就快速抛出ConcurrentModificationException错误,防止因为意外产生错误.
// 调用迭代器
public Iterator<E> iterator() {
return new Itr();
}
// ArrayList中自己实现的迭代器部分代码
private class Itr implements Iterator<E> {
int cursor; // index of next element to return
int lastRet = -1; // index of last element returned; -1 if no such
// 初始化时记录当前的操作数
int expectedModCount = modCount;
......
......
@SuppressWarnings("unchecked")
public E next() {
checkForComodification();
......
......
}
// 比对操作数的值是否有差异
final void checkForComodification() {
if (modCount != expectedModCount)
throw new ConcurrentModificationException();
}
}
值传递和引用传递, 深复制和浅复制
值传递和引用传递概念:
- 值传递(pass by value)是指在调用函数时将实际参数复制一份传递到函数中,这样在函数中如果对参数进行修改,将不会影响到实际参数.
- 引用传递(pass by reference)是指在调用函数时将实际参数的地址直接传递到函数中,那么在函数中对参数所进行的修改,将影响到实际参数.
在java中, 基本类型变量传递的是值的副本, 相当于把自己赋值一份传递,即使自己的副本变了,自己也不会改变.
而对象型变量, java传递的是引用的副本(复制指向地址的指针),而不是自己实际值的副本.所以传递后的对象被改变的话, 之前的对象也会同步改变.因为指向的内存中的实际对象被改变了.
P.S.在这里, String类型有些特殊, 一方面, String属于对象, 传递的是引用的副本, 另一方面,String的特殊结构(字符串常量都存在堆内存中的字符串常量池中), 且String不可更改, 只能创建新的.所以String传递后更改也不会影响之前的.
深复制和浅复制概念:
- 浅拷贝:对基本数据类型进行值传递,对引用数据类型进行引用传递般的拷贝,此为浅拷贝。
- 深拷贝:对基本数据类型进行值传递,对引用数据类型,创建一个新的对象,并复制其内容,此为深拷贝。
Collection中引用的System.arraycopy()就属于浅拷贝.
JAVA集合框架 - Collection的更多相关文章
- Java集合框架Collection
转自:http://www.cdtarena.com/javapx/201306/8891.html [plain] view plaincopyprint?01.在 Java2中,有一套设计优良的接 ...
- java集合框架collection(6)继承结构图
根据<java编程思想>里面的说法,java集合又叫容器,按照单槽和双槽分为两类,Collection和Map,这两个都是接口. 一.Collection Collection下面又分了三 ...
- java集合框架collection(4)HashMap和Hashtable的区别
HashMap和Hashtable的区别 HashMap和Hashtable都实现了Map接口,但决定用哪一个之前先要弄清楚它们之间的分别.主要的区别有:线程安全性,同步(synchronizatio ...
- java集合框架collection(3)Set、List和Map
Set.List和Map是java collection中最常用的三种数据结构. Set是集合,不允许有重复的元素,List是动态数组实现的列表,有序可重复,Map是key-value的键值对,用于快 ...
- java集合框架collection(5)HashMap和TreeMap
上图转载自:http://www.cnblogs.com/vamei/archive/2013/04/15/3000913.html 一.区别和联系 1.迭代器 迭代器是一种设计模式,它是一个对象,它 ...
- java集合框架collection(2)ArrayList和LinkedList
ArrayList是基于动态数组实现的list,而LinkedList是基于链表实现的list.所以,ArrayList拥有着数组的特性,LinkedList拥有着链表的特性. 优缺点 ArrayLi ...
- Java集合框架Collection(1)ArrayList的三种遍历方法
ArrayList是java最重要的数据结构之一,日常工作中经常用到的就是ArrayList的遍历,经过总结,发现大致有三种,上代码: package com.company; import java ...
- Java自学-集合框架 Collection
Java集合框架 Collection Collection是一个接口 步骤 1 : Collection Collection是 Set List Queue和 Deque的接口 Queue: 先进 ...
- Java集合框架之Collection接口
Java是一门面向对象的语言,那么我们写程序的时候最经常操作的便是对象了,为此,Java提供了一些专门用来处理对象的类库,这些类库的集合我们称之为集合框架.Java集合工具包位于Java.util包下 ...
随机推荐
- docker出现相同的image条目的删除办法
一.问题:在测试docker安装的prometheus系统时,由于异常操作,使用docker image ls出现了两条一模一样的条目,如下: [root@ELK prometheus]# docke ...
- Java实现字符串匹配
1 问题描述 给定一个n个字符组成的串(称为文本),一个m(m <= n)的串(称为模式),从文本中寻找匹配模式的子串. 2 解决方案 2.1 蛮力法 package com.liuzhen.c ...
- java实现识别复制串
** 识别复制串** 代码的目标:判断一个串是否为某个基本串的简单复制构成的. 例如: abcabcabc,它由"abc"复制3次构成,则程序输出:abc aa 由"a& ...
- Alink漫谈(六) : TF-IDF算法的实现
Alink漫谈(六) : TF-IDF算法的实现 目录 Alink漫谈(六) : TF-IDF算法的实现 0x00 摘要 0x01 TF-IDF 1.1 原理 1.2 计算方法 0x02 Alink示 ...
- javafx分别设置四个边框
package border; import javafx.application.Application; import javafx.geometry.Insets; import javafx. ...
- Java基础?看完以后再也不惧怕面试了
前言 这篇文章主要是Java基础部分,主要分为3个部分:Java集合.Java多线.JVM:这些东西帮助我面试成功率提升了很多.后面还有中间件Spring.Redis.RocketMQ等等吧,祝愿大家 ...
- [原创][开源]SunnyUI.Net, C# .Net WinForm开源控件库、工具类库、扩展类库、多页面开发框架
SunnyUI.Net, 基于 C# .Net WinForm 开源控件库.工具类库.扩展类库.多页面开发框架 Blog: https://www.cnblogs.com/yhuse Gitee: h ...
- vue2.0+Element UI 实现动态表单(点击按钮增删一排输入框)
对于动态增减表单项,Element UI 官方文档表单那一节已经介绍得很清楚了,我之前没有看见,绕了很多弯路,这里针对点击按钮增删一排输入框的问题做一个总结. 效果图如下 存在一排必填的姓名与手机号, ...
- react中的ref的3种方式
2020-03-31 react中的ref的3种方式 react中ref的3种绑定方式 方式1: string类型绑定 类似于vue中的ref绑定方式,可以通过this.refs.绑定的ref的名字获 ...
- 【loj - 6516】「雅礼集训 2018 Day11」进攻!
目录 description solution accepted code details description 你将向敌方发起进攻!敌方的防御阵地可以用一个 \(N\times M\) 的 \(0 ...