Java基础之Collection与Collections浅析
Java基础之Collection与Collections浅析
一、前言:
位于Java.util包下的Collection与Collections都是Java中重要的工具类,它们都是Java集合框架的成员,这俩个类对于Java基础不太好的朋友来说很容易搞混,现在我对其做一简单辨析
二、Collection简单介绍:
2.1Collection概述
Collection是Java集合框架的顶级接口(注意:它是一个接口),继承了Iterable接口
它提供了对集合对象进行基本操作的通用接口方法。Collection接口在Java 类库中有很多具体的实现。Collection接口的意义是为各种具体的集合提供了最大化的统一操作方式,其直接继承接口有List与Set。
Collection 表示一组对象,这些对象也称为 collection 的元素。一些 collection 允许有重复的元素,而另一些则不允许。一些 collection 是有序的,而另一些则是无序的。
2.2常用方法摘要:
- boolean add(E e)
- boolean addAll(Collection<? extends E> c)
- void clear()
- boolean contains(Object o)
- boolean containsAll(Collection<?> c)
- boolean equals(Object o)
- int hashCode()
- boolean isEmpty()
- Iterator<E> iterator()
- boolean remove(Object o)
- boolean removeAll(Collection<?> c)
- boolean retainAll(Collection<?> c)
- int size()
- Object[] toArray()
- <T> T[]toArray(T[] a)
三、collections简单介绍:
3.1Collections简单概述:
java.util.Collections 是一个包装类(工具类/帮助类)。它包含有各种有关集合操作的静态多态方法。此类不能实例化,就像一个工具类,用于对集合中元素进行排序、搜索以及线程安全等各种操作,服务于Java的Collection框架。
Collections中的方法都是静态方法,这正好体现了工具类的设计原则,便于开发者直接调用;
此类完全由在 collection 上进行操作或返回 collection 的静态方法组成。它包含在 collection 上操作的多态算法,即“包装器”,包装器返回由指定 collection 支持的新 collection,以及少数其他内容。
如果为此类的方法所提供的 collection 或类对象为 null,则这些方法都将抛出 NullPointerException。
此类中所含多态算法的文档通常包括对实现 的简短描述。应该将这类描述视为实现注意事项,而不是规范 的一部分。实现者应该可以随意使用其他算法替代,只要遵循规范本身即可。(例如,sort 使用的算法不一定是合并排序算法,但它必须是稳定的。)
此类中包含的“破坏性”算法,即可修改其所操作的 collection 的算法,该算法被指定在 collection 不支持适当的可变基元(比如 set 方法)时抛出 UnsupportedOperationException。如果调用不会对 collection 产生任何影响,那么这些算法可能(但不要求)抛出此异常。例如,在已经排序的、不可修改列表上调用 sort 方法可能会(也可能不会)抛出 UnsupportedOperationException。
3.2常用方法摘要:
|
addAll(Collection<? super T> c, T... elements) 将所有指定元素添加到指定 collection 中。 |
|
|
asLifoQueue(Deque<T> deque)以后进先出 (Lifo) Queue 的形式返回某个 Deque的视图。 |
|
|
binarySearch(List<? extends Comparable<? super T>> list, 使用二分搜索法搜索指定列表,以获得指定对象。 |
|
|
binarySearch(List<? extends使用二分搜索法搜索指定列表,以获得指定对象。 |
|
|
checkedCollection(Collection<E> c, Class<E> type)返回指定 collection 的一个动态类型安全视图。 |
|
|
checkedList(List<E> list,返回指定列表的一个动态类型安全视图。 |
|
|
checkedMap(Map<K,V> m, Class<K> keyType, Class<V> valueType)返回指定映射的一个动态类型安全视图。 |
|
|
checkedSet(Set<E> s, Class<E> type)返回指定 set 的一个动态类型安全视图。 |
|
|
checkedSortedMap(SortedMap<K,V> m, Class<K> keyType, Class<V> valueType)返回指定有序映射的一个动态类型安全视图。 |
|
|
checkedSortedSet(SortedSet<E> s, Class<E> type)返回指定有序 set 的一个动态类型安全视图。 |
|
|
copy(List<? super将所有元素从一个列表复制到另一个列表。 |
|
static boolean |
disjoint(Collection<?> c1, Collection<?> c2)如果两个指定 collection 中没有相同的元素,则返回 true。 |
|
|
emptyList()返回空的列表(不可变的)。 |
|
|
emptyMap()返回空的映射(不可变的)。 |
|
|
emptySet()返回空的 set(不可变的)。 |
|
|
enumeration(Collection<T> c)返回一个指定 collection 上的枚举。 |
|
|
fill(List<? super 使用指定元素替换指定列表中的所有元素。 |
|
static int |
frequency(Collection<?> c, Object o)返回指定 collection 中等于指定对象的元素数。 |
|
static int |
indexOfSubList(List<?> source, List<?> target)返回指定源列表中第一次出现指定目标列表的起始位置;如果没有出现这样的列表,则返回 -1。 |
|
static int |
lastIndexOfSubList(List<?> source, List<?> target)返回指定源列表中最后一次出现指定目标列表的起始位置;如果没有出现这样的列表,则返回 -1。 |
|
|
list(Enumeration<T> e)返回一个数组列表,它按返回顺序包含指定枚举返回的元素。 |
|
|
max(Collection<? extends 根据元素的自然顺序,返回给定 collection 的最大元素。 |
|
|
max(Collection<? extends T> coll, 根据指定比较器产生的顺序,返回给定 collection 的最大元素。 |
|
|
min(Collection<? extends 根据元素的自然顺序 返回给定 collection 的最小元素。 |
|
|
min(Collection<? extends T> coll, 根据指定比较器产生的顺序,返回给定 collection 的最小元素。 |
|
|
nCopies(int n, 返回由指定对象的 n 个副本组成的不可变列表。 |
|
|
newSetFromMap(Map<E,Boolean> map)返回指定映射支持的 set。 |
|
|
replaceAll(List<T> list, 使用另一个值替换列表中出现的所有某一指定值。 |
|
static void |
reverse(List<?> list)反转指定列表中元素的顺序。 |
|
|
reverseOrder()返回一个比较器,它强行逆转实现了 Comparable 接口的对象 collection 的自然顺序。 |
|
|
reverseOrder(Comparator<T> cmp)返回一个比较器,它强行逆转指定比较器的顺序。 |
|
static void |
rotate(List<?> list, 根据指定的距离轮换指定列表中的元素。 |
|
static void |
shuffle(List<?> list)使用默认随机源对指定列表进行置换。 |
|
static void |
shuffle(List<?> list,使用指定的随机源对指定列表进行置换。 |
|
|
singleton(T o)返回一个只包含指定对象的不可变 set。 |
|
|
singletonList(T o)返回一个只包含指定对象的不可变列表。 |
|
|
singletonMap(K key, 返回一个不可变的映射,它只将指定键映射到指定值。 |
|
|
sort(List<T> list)根据元素的自然顺序 对指定列表按升序进行排序。 |
|
|
sort(List<T> list,根据指定比较器产生的顺序对指定列表进行排序。 |
|
static void |
swap(List<?> list, 在指定列表的指定位置处交换元素。 |
|
|
synchronizedCollection(Collection<T> c)返回指定 collection 支持的同步(线程安全的)collection。 |
|
|
synchronizedList(List<T> list)返回指定列表支持的同步(线程安全的)列表。 |
|
|
synchronizedMap(Map<K,V> m)返回由指定映射支持的同步(线程安全的)映射。 |
|
|
synchronizedSet(Set<T> s) 返回指定 set 支持的同步(线程安全的)set。 |
|
|
synchronizedSortedMap(SortedMap<K,V> m)返回指定有序映射支持的同步(线程安全的)有序映射。 |
|
|
synchronizedSortedSet(SortedSet<T> s)返回指定有序 set 支持的同步(线程安全的)有序 set。 |
|
|
unmodifiableCollection(Collection<? extends 返回指定 collection 的不可修改视图。 |
|
|
unmodifiableList(List<? extends 返回指定列表的不可修改视图。 |
|
|
unmodifiableMap(Map<? extends K,? 返回指定映射的不可修改视图。 |
|
|
unmodifiableSet(Set<? extends 返回指定 set 的不可修改视图。 |
|
|
unmodifiableSortedMap(SortedMap<K,? extends 返回指定有序映射的不可修改视图。 |
|
|
unmodifiableSortedSet(SortedSet<T> s)返回指定有序 set 的不可修改视图。 |
四、Collection与Collections的异同:
- 相同点:二者都是Java集合框架的成员,都位于java.util包下
- 不同之处:Collection是Java集合框架的顶级接口,继承自Iterable,他是一个泛型接口,充分的体现了Java的多态性
Collections是Java集合框架的工具类,服务于Collection。提供了对Java集合操作的各种静态方法
参考:https://baike.baidu.com/item/COLLECTION/80124?fr=aladdin
Java基础之Collection与Collections浅析的更多相关文章
- Java基础之多态和泛型浅析
Java基础之多态和泛型浅析 一.前言: 楼主看了许多资料后,算是对多态和泛型有了一些浅显的理解,这里做一简单总结 二.什么是多态? 多态(Polymorphism)按字面的意思就是“多种状态”.在面 ...
- Java学习笔记--Collection和Collections的区别
转自 http://pengcqu.iteye.com/blog/492196 比较Collection 和Collections的区别. 1.java.util.Collection 是一个集合 ...
- Java基础学习-Collection体系结构和迭代测试
package Collection; import java.util.ArrayList; import java.util.Collection; import java.util.Iterat ...
- ——Java中的collection和collections的区别
1.java.util.Collection 是一个集合接口(集合类的一个顶级接口).它提供了对集合对象进行基本操作的通用接口方法.Collection接口在Java 类库中有很多具体的实现.Coll ...
- 【JAVA - 基础】之Annotation注解浅析
注解在JAVA中,尤其是一些ORM框架(如Hibernate等)中是比较常用的一种机制. 注解是JAVA 1.5之后引入的新功能,正确来说是反射的一部分,没有反射,注解也就无法正常使用.注解可以理解成 ...
- Java基础学习-Collection
package Collection; import java.util.ArrayList; import java.util.Scanner; /*集合类的特点: * 大小可变 * * Array ...
- java基础-Comparator接口与Collections实现排序算法
java 排序Comparable和Comparator使用 java提供了两个排序用的接口Comparable和Comparator,一般情况下使用区别如下: Comparable 接口用于类的固定 ...
- Java基础之Comparable接口, Collections类,Iterator接口,泛型(Generic)
一.Comparable接口, Collections类 List的常用算法: sort(List); 排序,如果需要对自定义的类进行排序, 那就必须要让其实现Comparable接口, 实现比较两个 ...
- Java集合(三)--Collection、Collections和Arrays
Collection: Collection是集合类的顶级接口,提供了对集合对象进行基本操作的通用接口方法.Collection接口的意义是为各种具体的集合提供了最大化 的统一操作方式,其直接继承接口 ...
随机推荐
- 第一篇:开始进入 django 之旅
文中所有示例代码的仓库地址:https://github.com/HelloGitHub-Team/HelloDjango-blog-tutorial 开发环境说明 本教程写作时开发环境的系统平台为 ...
- 【剑指offer】面试题(三)
package com.haxianhe.test; /** *题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序, *每一列都按照从上到下递增的顺序排序. *请完成一个函数, *输入这样的一 ...
- CF175C Geometry Horse(贪心)
CF175C 贪心,注意有不少细节,很容易死循环TLE 贪心是显而易见的,每次枚举价值最小的物品,进行销毁操作 朴素的枚举每一件物品复杂度为\(O(\sum k_i)\),明显超时 我们注意到朴素的+ ...
- ubuntu环境下测试cache大小并校验
Cache存储器:电脑中为高速缓冲存储器,是位于CPU和主存储器DRAM(Dynamic Random Access Memory)之间,规模较小,但速度很高的存储器,通常由SRAM(Static R ...
- HZOJ 单
两个子任务真的是坑……考试的时候想到了60分的算法,然而只拿到了20分(各种沙雕错,没救了……). 算法1: 对于测试点1,直接n遍dfs即可求出答案,复杂度O(n^2),然而还是有好多同学跑LCA/ ...
- three出现状态200的报错
报错代码如下: {status: 200, data: {…}} "sa_SpringUserFindOneView_findPbUserByUserId"header.vue?1 ...
- 【iOS】沙盒目录
有关沙盒目录参考: http://blog.csdn.net/totogo2010/article/details/7669837 获取沙盒路径,参考代码: NSArray *paths = NSSe ...
- 二进制文件安装k8s所需要的证书服务
利用二进制文件安装etcd所需要的证书服务 CFSSL是CloudFlare开源的一款PKI/TLS工具. CFSSL 包含一个命令行工具 和一个用于 签名,验证并且捆绑TLS证书的 HTTP API ...
- 一看就懂的K近邻算法(KNN),K-D树,并实现手写数字识别!
1. 什么是KNN 1.1 KNN的通俗解释 何谓K近邻算法,即K-Nearest Neighbor algorithm,简称KNN算法,单从名字来猜想,可以简单粗暴的认为是:K个最近的邻居,当K=1 ...
- UE4 代理 BindRaw和BindUObject
代理允许您在C++对象上以通用的但类型安全的方式调用成员函数.通过使用代理,可以将其动态地绑定到任何对象的成员函数上,然后在该对象上调用函数,即时调用者不知道该对象的类型也没关系. 任何时候都应该通过 ...