Collection集合
一些关于集合内部算法可以查阅这篇文章《容器类总结》。
(Abstract+)
Collection
增:
- add(E):boolean
- addAll(Collection<? extends E>):boolean
删:
- remove(Object):boolean
- removeAll(Collection<?>):boolean
- retainAll(Collection<?>):boolean
- removeIf(Predicate<? super E>):boolean
- clear()
查:
- contains(Object):boolean
- containsAll(Collection<?>):boolean
- size():int
- isEmpty():boolean
- toArray():Object[]
- toArray(T[]):T[]
- Collections.max(Collection<? extends T>):T
- Collections.max(Collection<? extends T>, Comparator<? super T>):T
求最大值 - Collections.min(Collection<? extends T>):T
- Collections.min(Collection<? extends T>, Comparator<? super T>):T
求最小值
工具:
- iterator():Iterator<E>
- spliterator():Spliterator<E>
- stream():Stream<E>
- parallelStream():Stream<E>
- Collections.unmodifiableCollection(Collection<? extends T>):Collection<T>
只读模式包装 - Collections.synchronizedCollection(Collection<T>):Collection<T>
线程安全包装
(Abstract+)
(AbstractSequentia+)
List
父类:Collection
子类:ArrayList,LinkedList,Vector,Stack
增:
- add(int, E)
- addAll(int, Collection<? extends E>):boolean
删:
- remove(int):E
改:
- set(int, E):E
- replaceAll(UnaryOperator<E>)
- sort(Comparator<? super E>)
- Collections.swap(List<?>, int, int)
交换两元素位置
查:
- get(int):E
- indexOf(Object):int
- lastIndexOf(Object):int
- subList(int, int):List<E>
子集
工具:
- listIterator():ListIterator<E>
- listIterator(int):ListIterator<E>
- Collections.unmodifiableList(List<? extends T>):List<T>
只读模式包装 - Collections.synchronizedList(List<T>):List<T>
线程安全包装
ArrayList
父类:List,Collection
改:
- ensureCapacity(int)
- trimToSize()
LinkedList
父类:List,Deque,Queue,Connection
特征:链式存储
Vector
父类:List,Collection
子类:Stack
特征:线程安全
增:
- addElement(E)
- insertElementAt(E, int)
删:
- removeAllElements()
- removeElement(Object):boolean
- removeElementAt(int)
改:
- setElementAt(E, int)
- setSize(int)
- ensureCapacity(int)
- trimToSize()
查:
- firstElement():E
- lastElement():E
- elementAt(int):E
- elements():Enumeration<E>
- indexOf(Object, int):int
- lastIndexOf(Object, int):int
- capacity():int
- copyInto(Object[])
Stack
父类:Vector,List,Collection
特征:线程安全;先入后出
增:
- push(E):E
删:
- pop():E
改:
- peek():E
- search(Object):int
- empty():boolean
(Abstract+)
Queue
父类:Collection
子类:Deque,ConcurrentLinkedQueue,BlockingQueue,LinkedList
增:
- offer(E):boolean
删:
- poll():E
- remove():E
查:
- peek():E
- element():E
ConcurrentLinkedQueue
父类:Queue,Collection
特征:链式存储;线程安全;先进先出
BlockingQueue
父类:Queue,Collection
子类:ArrayBlockingQueue,LinkedBlockingQueue,PriorityBlockingQueue,DelayQueue,
SynchronousQueue,TransferQueue,LinkedTransferQueue,BlockingDeque
增:
- offer(E, long, TimeUnit):boolean
- put(E)
删:
- poll(long, TimeUnit):E
- take():E
- drainTo(Collection<? super E>):int
- drainTo(Collection<? super E>, int):int
查:
- remainingCapacity():int
ArrayBlockingQueue
父类:BlockingQueue,Queue,Collection
特征:线程安全;先进先出;队满时阻塞进队线程;队空时阻塞出队线程;
LinkedBlockingQueue
父类:BlockingQueue,Queue,Collection
特征:链式存储;线程安全;先进先出;队满时阻塞进队线程;队空时阻塞出队线程;
PriorityBlockingQueue
父类:BlockingQueue,Queue,Collection
特征:线程安全;策略排序;队空时阻塞出队线程;
查:
- comparator():Comparator<? super E>
DelayQueue<E extends Delayed>
父类:BlockingQueue,Queue,Collection
特证:线程安全;策略排序;队空时或队头未到期时,阻塞出队线程;
SynchronousQueue
父类:BlockingQueue,Queue,Collection
特征:线程安全;先进后出;元素进队(put)后,阻塞进队线程,至元素出队为止;队空时阻塞出队线程;
TransferQueue
父类:BlockingQueue,Queue,Collection
增:
- transfer(E)
- tryTransfer(E):boolean
- tryTransfer(E, long, TimeUnit):boolean
查:
- getWaitingConsumerCount():int
- hasWaitingConsumer():boolean
LinkedTransferQueue
父类:TransferQueue,BlockingQueue,Queue,Collection
特征:线程安全;先进先出;元素进队(transfer)后,阻塞进队线程,至元素出队为止;队空时阻塞出队线程;
Deque
父类:Queue,Collection
子类:ArrayDeque,BlockingDeque,LinkedList
增:
- addFirst(E)
- addLast(E)
- offerFirst(E):boolean
- offerLast(E):boolean
- push(E):void
删:
- removeFirst():E
- removeLast():E
- removeFirstOccurrence(Object):boolean
- removeLastOccurrence(Object):boolean
- pollFirst():E
- pollLast():E
- pop():E
查:
- getFirst():E
- getLast():E
- peekFirst():E
- peekLast():E
工具:
- descendingIterator():Iterator<E>
ArrayDeque
父类:Deque,Queue,Collection
BlockingDeque
父类:Deque,BlockingQueue,Queue,Collection
增:
- offerFirst(E, long, TimeUnit):boolean
- offerLast(E, long, TimeUnit):boolean
- putFirst(E)
- putLast(E)
删:
- pollFirst(long, TimeUnit):E
- pollLast(long, TimeUnit):E
- takeFirst():E
- takeLast():E
LinkedBlockingDeque
父类:BlockingDeque,BlockingQueue,Deque,Queue,Collection
(Abstract+)
Set
父类:Collection
子类:HashSet,TreeSet,SortedSet,NavigableSet,EnumSet
特征:代表不可重复序列
工具:
- Collections.unmodifiableSet(Set<? extends T>):Set<T>
只读模式包装 - Collections.synchronizedSet(Set<E>):Set<E>
线程安全包装
HashSet
父类:Set,Collection
特征:不可重复;策略排序(哈希表算法),一般代表无序
LinkedHashSet
父类:HashSet,Set,Collection
特征:不可重复;保留加入序
SortedSet
父类:Set,Collection
特征:代表有序
查:
- first():E
- last():E
- headSet(E):SortedSet<E>
- tailSet(E):SortedSet<E>
- subSet(E, E):SortedSet<E>
- comparator():Comparator<? super E>
工具:
- Collections.synchronizedSortedSet(SortedSet<T>):SortedSet<T>
线程安全包装 - Collections.unmodifiableSortedSet(SortedSet<T>):SortedSet<T>
只读模式包装
NavigableSet
子类:TreeSet
特征:提供高级操作
删:
- pollFirst():E
- pollLast():E
查:
- ceiling(E):E
- floor(E):E
- higher(E):E
- lower(E):E
- headSet(E, boolean):NavigableSet<E>
- tailSet(E, boolean):NavigableSet<E>
- subSet(E, boolean, E, boolean):NavigableSet<E>
- descendingSet():NavigableSet<E>
工具:
- descendingIterator():Iterator<E>
- Collections.unmodifiableNavigableSet(NavigableSet<T>):NavigableSet<T>
只读模式包装 - Collections.synchronizedNavigableSet(NavigableSet<T>):NavigableSet<T>
线程安全包装
TreeSet
父类:NavigableSet,SortedSet,Set,Collection
特征:不可重复;策略排序(红黑树算法);不能有空元素
EnumSet<E extends Enum<E>>
父类:Set,Collection
特征:用于枚举类型
构建:
- s+allOf(Class<E>):ElemSet<E>
全集 - s+noneOf(Class<E>):ElemSet<E>
空集 - s+copyOf(Collection<E>):ElemSet<E>
- s+copyOf(EnumSet<E>):ElemSet<E>
- s+complementOf(EnumSet<E>):ElemSet<E>
补集 - s+of(E...):ElemSet<E>
- s+range(E, E):ElemSet<E>
待续更新!
Collection集合的更多相关文章
- 浅谈Collection集合
俗话说:一个东西,一件事都离不开三句话:"是什么,为什么,怎么办" 集合是什么: 集合简单的说一个数组集合的高级体现,用来存储数据或对象的容器: 集合为什么存在: 集合只是体现了对 ...
- Collection集合的功能及总结
Collection集合是集合顶层接口,不能实例化 功能 1.添加功能 boolean add(Object obj):添加一个元素 boolean addAll(Collection c):添加一个 ...
- JAVA collection集合之 扑克牌游戏
主要内容:这里使用collection集合,模拟香港电影中大佬们玩的扑克牌游戏. 1.游戏规则:两个玩家每人手中发两张牌,进行比较.比较每个玩家手中牌最大的点数,大小由A-2,点数大者获胜.如果点数相 ...
- Collection集合List、Set
Collection集合,用来保存一组数据的数据结构. Collection是一个接口,定义了所有集合都应该包含的特征和行为 Collection派生出了两类集合 List和Set List接口:Li ...
- Collection集合之六大接口(Collection、Set、List、Map、Iterator和Comparable)
首先,我们先看一下Collection集合的基本结构: 1.Collection接口 Collection是最基本集合接口,它定义了一组允许重复的对象.Collection接口派生了两个子接口Set和 ...
- java.util.Map按照key值合并的value的Collection 集合中。
用java实现把多个map的内容合并的一个resultMap中 代码大致如下 /** * @author Shalf */ public class MapUtil { /** * 把partMa ...
- javad的Collection集合
集合框架:★★★★★,用于存储数据的容器. 特点: 1:对象封装数据,对象多了也需要存储.集合用于存储对象. 2:对象的个数确定可以使用数组,但是不确定怎么办?可以用集合.因为集合是可变长度的. 集合 ...
- Java基础知识强化之集合框架笔记13:Collection集合存储学生对象并遍历
1. Collection集合存储学生对象并遍历: 需求:存储自定义对象并遍历Student(name,age) 分析: (1)创建学生类 (2)创建集合对象 (3)创建学生对象 (4)把学生对象添加 ...
- Java基础知识强化之集合框架笔记12:Collection集合存储字符串并遍历
1. Collection集合存储字符串并遍历 分析: (1)创建集合对象 (2)创建字符串对象 (3)把字符串对象添加到集合中 (4)遍历集合 2. 代码示例: package cn.itcast ...
- Java基础知识强化之集合框架笔记09:Collection集合迭代器使用的问题探讨
1.Collection集合迭代器使用的问题探讨: (1)问题1:能用while循环写这个程序,我能不能用for循环呢? 可以使用for循环替代. (2)问题2:不要 ...
随机推荐
- Cmder--Windows下命令行利器
cmder cmder是一个增强型命令行工具,不仅可以使用windows下的所有命令,更爽的是可以使用linux的命令,shell命令. 安装包 安装包链接 下载后,直接解压即用. 修改命令提示符λ为 ...
- 开源:Taurus.MVC 框架
为什么要创造Taurus.MVC: 记得被上一家公司忽悠去负责公司电商平台的时候,情况是这样的: 项目原版是外包给第三方的,使用:WebForm+NHibernate,代码不堪入目,Bug无限,经常点 ...
- nginx的使用
1.nginx的下载 解压后文件目录: 2.nginx的常用命令 nginx -s stop 强制关闭 nginx -s quit 安全关闭 nginx -s reload 改变配置文件的时候,重 ...
- 从备考PMP到与项目经理同呼吸
前言 PMP是什么梗? 项目管理专业人士资格认证.它是由美国项目管理协会(Project Management Institute(PMI)发起的,严格评估项目管理人员知识技能是否具有高品质的资格认证 ...
- C#基础篇 - 正则表达式入门
1.基本概念 正则表达式(Regular Expression)就是用事先定义好的一些特定字符(元字符)或普通字符.及这些字符的组合,组成一个“规则字符串”,这个“规则字符串”用来判断我们给定的字符串 ...
- .NET平台开源项目速览(18)C#平台JSON实体类生成器JSON C# Class Generator
去年,我在一篇文章用原始方法解析复杂字符串,json一定要用JsonMapper么?中介绍了简单的JSON解析的问题,那种方法在当时的环境是非常方便的,因为不需要生成实体类,结构很容易解析.但随着业务 ...
- angular2系列教程(十)两种启动方法、两个路由服务、引用类型和单例模式的妙用
今天我们要讲的是ng2的路由系统. 例子
- 套用JQuery EasyUI列表显示数据、分页、查询
声明,本博客从csdn搬到cnblogs博客园了,以前的csdn不再更新,朋友们可以到这儿来找我的文章,更多的文章会发表,谢谢关注! 有时候闲的无聊,看到extjs那么肥大,真想把自己的项目改了,最近 ...
- 在开启DRS的集群中修复VMware虚拟主机启动问题
通过iSCSI方式连接到ESXi主机上的外挂存储意外失联了一段时间,导致部分虚拟主机在集群中呈现出孤立的状态,单独登陆到每台ESXi上可以看到这些虚拟主机都变成了unknow状态.因为有过上一次(VM ...
- MVC还是MVVM?或许VMVC更适合WinForm客户端
最近开始重构一个稍嫌古老的C/S项目,原先采用的技术栈是『WinForm』+『WCF』+『EF』.相对于现在铺天盖地的B/S架构来说,看上去似乎和Win95一样古老,很多新入行的,可能就没有见过经典的 ...