java的集合工具类Collections
集合框架的工具类。
Collections:集合框架的工具类。里面定义的都是静态方法。
Collections和Collection有什么区别?
Collection是集合框架中的一个顶层接口,它里面定义了单列集合的共性方法。
它有两个常用的子接口:
List:对元素都有定义索引。有序的。可以重复元素。
Set:不可以重复元素。无序。
Collections是集合框架中的一个工具类。该类中的方法都是静态的
提供的方法中有可以对list集合进行排序,二分查找等方法。
通常常用的集合都是线程不安全的。因为要提高效率。
如果多线程操作这些集合时,可以通过该工具类中的同步方法,将线程不安全的集合,转换成安全的。
Collections常用方法
排序
static <T extends Comparable<? super T>> void
sort(List<T> list)
根据元素的自然顺序 对指定列表按升序进行排序 <T extends Comparable> 要排序的对象必须是Comparable的子类
static <T> void
sort(List<T> list, Comparator<? super T> c)
根据指定比较器产生的顺序对指定列表进行排序。 自定义比较器排序
最大值最小值
static <T extends Object & Comparable<? super T>> T
max(Collection<? extends T> coll)
根据元素的自然顺序,返回给定 collection 的最大元素。
static <T> T
max(Collection<? extends T> coll, Comparator<? super T> comp)
根据指定比较器产生的顺序,返回给定 collection 的最大元素。
最小值同理
二分法查找
static <T> int
binarySearch(List<? extends Comparable<? super T>> list, T key)
使用二分搜索法搜索指定列表,以获得指定对象。
如果搜索键包含在列表中,则返回搜索键的索引;否则返回 (-(插入点) - 1)。
插入点:即第一个大于此键的元素索引
static <T> int
binarySearch(List<? extends T> list, T key, Comparator<? super T> c)
使用二分搜索法搜索指定列表,自定义比较器,以获得指定对象。
替换所有
static <T> void
fill(List<? super T> list, T obj)
使用指定元素替换指定列表中的所有元素。
static <T> boolean
replaceAll(List<T> list, T oldVal, T newVal)
使用另一个值替换列表中出现的所有某一指定值。
反转
static void
reverse(List<?> list)
反转指定列表中元素的顺序。
static <T> Comparator<T>
reverseOrder()
返回一个比较器,它强行逆转实现了 Comparable 接口的对象 collection 的自然顺序。
static <T> Comparator<T>
reverseOrder(Comparator<T> cmp)
返回一个比较器,它强行逆转指定比较器的顺序。
洗牌
static void
shuffle(List<?> list)
使用默认随机源对指定列表进行置换。
static void
shuffle(List<?> list, Random rnd)
使用指定的随机源对指定列表进行置换。
将集合转换成线程安全的集合
static <T> Collection<T>
synchronizedCollection(Collection<T> c)
返回指定 collection 支持的同步(线程安全的)collection。
static <T> List<T>
synchronizedList(List<T> list)
返回指定列表支持的同步(线程安全的)列表。
static <K,V> Map<K,V>
synchronizedMap(Map<K,V> m)
返回由指定映射支持的同步(线程安全的)映射。
static <T> Set<T>
synchronizedSet(Set<T> s)
返回指定 set 支持的同步(线程安全的)set。
static <K,V> SortedMap<K,V>
synchronizedSortedMap(SortedMap<K,V> m)
返回指定有序映射支持的同步(线程安全的)有序映射。
static <T> SortedSet<T>
synchronizedSortedSet(SortedSet<T> s)
返回指定有序 set 支持的同步(线程安全的)有序 set。
public class CollectionsDemo {
public static void main(String[] args) {
// sort1();
// sort2();
// binarySearchDemo();
// binarySearchDemo2();
// fillDemo();
// reverseOrderDemo();
shuffleDemo();
}
public static void shuffleDemo(){
ArrayList<String> al = new ArrayList<String>();
al.add("a");
al.add("b");
al.add("c");
al.add("d");
al.add("e");
System.out.println("原集合:"+al); // 原集合:[a, b, c, d, e]
Collections.shuffle(al);
System.out.println("洗牌后的集合:"+al); //洗牌后的集合:[e, b, a, d, c]
}
public static void reverseOrderDemo(){
// reverseOrder(Comparator<T> cmp) 强行逆转自定义的比较器
TreeSet<String> ts = new TreeSet<String>(Collections.reverseOrder(new StringLengthComparator()));
ts.add("abb");
ts.add("azcc");
ts.add("aeee");
ts.add("bc");
for(Iterator<String> it = ts.iterator();it.hasNext();){
System.out.println(it.next());
}
/* azcc
aeee
abb
bc*/
}
public static void reverseOrderDemo2(){
// Collections.reverseOrder()强行逆转实现了 Comparable 接口的对象 collection 的自然顺序
TreeSet<String> ts = new TreeSet<String>(Collections.reverseOrder());
ts.add("abb");
ts.add("azcc");
ts.add("aeee");
ts.add("bc");
for(Iterator<String> it = ts.iterator();it.hasNext();){
System.out.println(it.next());
}
}
public static void fillDemo(){
ArrayList<String> al = new ArrayList<String>();
al.add("aa");
al.add("bbb");
al.add("d");
al.add("cccc");
al.add("eee");
al.add("eee");
System.out.println("原集合:"+al); // 原集合:[aa, bbb, d, cccc, eee, eee]
// Collections.fill(al,"sd");
// System.out.println("替换后的:"+al); // 替换后的:[sd, sd, sd, sd, sd, sd]
Collections.replaceAll(al,"eee","fff");
System.out.println("替换后的:"+al); //替换后的:[aa, bbb, d, cccc, fff, fff]
}
public static void binarySearchDemo(){
ArrayList<String> al = new ArrayList<String>();
al.add("aa");
al.add("bbb");
al.add("d");
al.add("cccc");
al.add("eee");
al.add("eee");
Collections.sort(al);
System.out.println("排序后:"+al); // 排序后:[aa, bbb, cccc, d, eee, eee]
System.out.println(Collections.binarySearch(al,"eee")); // 4
System.out.println(Collections.binarySearch(al,"bbbb")); //-3 -(插入点)-1
}
// 自定义比较器查找
public static void binarySearchDemo2(){
ArrayList<String> al = new ArrayList<String>();
al.add("aa");
al.add("bbb");
al.add("d");
al.add("cccc");
al.add("eee");
al.add("eee");
Collections.sort(al,new StringLengthComparator());
System.out.println("排序后:"+al); // 排序后:[d, aa, bbb, eee, eee, cccc]
System.out.println(Collections.binarySearch(al,"bbb",new StringLengthComparator())); // 2
System.out.println(Collections.binarySearch(al,"bbbb",new StringLengthComparator())); //-6 -(插入点)-1
}
public static void sort1() {
ArrayList<String> al = new ArrayList<String>();
al.add("aa");
al.add("bbb");
al.add("d");
al.add("cccc");
al.add("eee");
al.add("eee");
System.out.println("原集合:"+al); // 原集合:[aa, bbb, d, cccc, eee, eee]
Collections.sort(al);
System.out.println("排序后的集合"+al); // 排序后的集合[aa, bbb, cccc, d, eee, eee]
System.out.println("最大值:"+Collections.max(al)); // 最大值:eee
}
public static void sort2() {
ArrayList<String> al = new ArrayList<String>();
al.add("aa");
al.add("bbb");
al.add("d");
al.add("cccc");
al.add("eee");
al.add("eee");
System.out.println("原集合:"+al); // 原集合:[aa, bbb, d, cccc, eee, eee]
Collections.sort(al,new StringLengthComparator());
System.out.println("排序后的集合"+al); // 排序后的集合[d, aa, bbb, eee, eee, cccc]
System.out.println("最大值:"+Collections.max(al,new StringLengthComparator())); // 最大值:eee
}
}
// 自定义比较器,按照长度进行排序
class StringLengthComparator implements Comparator<String>{
@Override
public int compare(String o1, String o2) {
int num = new Integer(o1.length()).compareTo(new Integer(o2.length()));
if(num == 0){
return o1.compareTo(o2);
}
return num;
}
}
Arrays
此类包含用来操作数组(比如排序和搜索)的各种方法。此类还包含一个允许将数组作为列表来查看的静态工厂
Arrays常用方法
查找(支持各种类型)
static int
binarySearch(byte[] a, byte key)
使用二分搜索法来搜索指定的 byte 型数组,以获得指定的值。
static int
binarySearch(byte[] a, int fromIndex, int toIndex, byte key)
使用二分搜索法来搜索指定的 byte 型数组的范围,以获得指定的值。
static <T> int
binarySearch(T[] a, int fromIndex, int toIndex, T key, Comparator<? super T> c)
使用二分搜索法来搜索指定数组的范围,以获得指定对象。 自定义比较器
static <T> int
binarySearch(T[] a, T key, Comparator<? super T> c)
使用二分搜索法来搜索指定数组,以获得指定对象。 自定义比较器
复制(支持各种类型)
static float[]
copyOf(float[] original, int newLength)
复制指定的数组,截取或用 0 填充(如有必要),以使副本具有指定的长度。
static char[]
copyOfRange(char[] original, int from, int to)
将指定数组的指定范围复制到一个新数组。
比较是否相等(支持各种类型)
static boolean
deepEquals(Object[] a1, Object[] a2)
如果两个指定数组彼此是深层相等 的,则返回 true。
static int
deepHashCode(Object[] a)
基于指定数组的“深层内容”返回哈希码。
static String
deepToString(Object[] a)
返回指定数组“深层内容”的字符串表示形式。
static boolean
equals(boolean[] a, boolean[] a2)
如果两个指定的 boolean 型数组彼此相等,则返回 true。
替换(支持各种类型)
static void
fill(int[] a, int val)
将指定的 int 值分配给指定 int 型数组的每个元素。
排序
static void
sort(int[] a)
对指定的 int 型数组按数字升序进行排序。
static void
sort(int[] a, int fromIndex, int toIndex)
对指定 int 型数组的指定范围按数字升序进行排序。
static <T> void
sort(T[] a, Comparator<? super T> c)
根据指定比较器产生的顺序对指定对象数组进行排序。 自定义比较器(进行降序)
static <T> void
sort(T[] a, int fromIndex, int toIndex, Comparator<? super T> c)
根据指定比较器产生的顺序对指定对象数组的指定范围进行排序。
数组以字符串形式输出
static String
toString(long[] a)
返回指定数组内容的字符串表示形式。
数值转集合
static <T> List<T>
asList(T... a)
返回一个受指定数组支持的固定大小的列表。(不支持增删)
import java.util.Arrays;
import java.util.List;
public class ArraysDemo {
public static void main(String[] args) {
/*
如果数组中的元素都是对象。那么变成集合时,数组中的元素就直接转成集合中的元素。
如果数组中的元素都是基本数据类型,那么会将该数组作为集合中的元素存在。
*/
int[] arr = {2,3,5};
// toString(arr)
System.out.println(Arrays.toString(arr)); // [2, 3, 5]
// 数组转List
//把数组变成list集合有什么好处?
/*
可以使用集合的思想和方法来操作数组中的元素。
注意:将数组变成集合,不可以使用集合的增删方法。
因为数组的长度是固定。
contains。
get
indexOf()
subList();
如果你增删。那么会反生UnsupportedOperationException,
*/
String[] s ={"aaa","bbb","c"};
List<String> list = Arrays.asList(s);
System.out.println(list); // [aaa, bbb, c]
System.out.println(list.contains("ss")); // false
/*
如果数组中的元素都是对象。那么变成集合时,数组中的元素就直接转成集合中的元素。
如果数组中的元素都是基本数据类型,那么会将该数组作为集合中的元素存在。
*/
//int[] nums = {2,4,5}; // 会是一个地址列表中有个地址
Integer[] nums = {2,4,5};
List<Integer> li = Arrays.asList(nums);
System.out.println(li); // [2, 4, 5]
}
}
集合转数组
Collection 类中的方法
Object[] toArray()
返回包含此 collection 中所有元素的数组。
<T> T[]
toArray(T[] a)
返回包含此 collection 中所有元素的数组;返回数组的运行时类型与指定数组的运行时类型相同。
import java.util.ArrayList;
import java.util.Arrays;
public class toArrayDemo {
public static void main(String[] args) {
ArrayList<String> al = new ArrayList<String>();
al.add("abc1");
al.add("abc2");
al.add("abc3");
/*
1,指定类型的数组到底要定义多长呢?
当指定类型的数组长度小于了集合的size,那么该外汇返佣方法内部会创建一个新的数组。长度为集合的size。
当指定类型的数组长度大于了集合的size,就不会新创建了数组。而是使用传递进来的数组。
所以创建一个刚刚好的数组最优。
2,为什么要将集合变数组?
为了限定对元素的操作。不需要进行增删了。
*/
String[] arr = al.toArray(new String[al.size()]);
System.out.println(Arrays.toString(arr));
}
}
1.5 新特性
高级for循环
格式:
for(数据类型 变量名 : 被遍历的集合(Collection)或者数组)
{
}
对集合进行遍历。只能获取集合元素。但是不能对集合进行操作。
迭代器除了遍历,还可以进行remove集合中元素的动作。
如果是用ListIterator,还可以在遍历过程中对集合进行增删改查的动作。
传统for和高级for有什么区别呢?
高级for有一个局限性。必须有被遍历的目标。
建议在遍历数组的时候,还是希望是用传统for。因为传统for可以定义脚标。
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class forDemo {
public static void main(String[] args) {
ArrayList<String> al = new ArrayList<String>();
al.add("abc1");
al.add("abc2");
al.add("abc3");
for(String s : al){
System.out.println(s);
}
HashMap<Integer,String> map = new HashMap<Integer, String>();
map.put(1,"a");
map.put(2,"b");
map.put(3,"c");
//使用keySet进行遍历
Set<Integer> keySet= map.keySet();
for (Integer k : keySet){
System.out.println(k+":"+map.get(k));
}
//使用entrySet进行遍历
Set<Map.Entry<Integer,String>> entryKey = map.entrySet();
for (Map.Entry<Integer,String > entry : entryKey){
System.out.println(entry.getKey()+"--"+entry.getValue());
}
// 简化
for(Map.Entry<Integer,String> entry : map.entrySet()){
System.out.println(entry.getKey()+"--"+entry.getValue());
}
}
}
方法的可变参数。
import java.util.Arrays;
/*
JDK1.5版本出现的新特性。
方法的可变参数。
在使用时注意:可变参数一定要定义在参数列表最后面。
*/
public class ParamMethodDemo {
public static void main(String[] args) {
/*
可变参数。
其实就是上一种数组参数的简写形式。
只要将要操作的元素作为参数传递即可。
隐式将这些参数封装成了数组。
*/
show("hahaha",1,2,3); // 可变参数一定要定义在参数列表最后面。
int[] b = {1,33,6};
show("hahaha",b);
}
public static void show(String s, int ... a){
System.out.println(s);
System.out.println(a); //[I@4554617c
System.out.println(Arrays.toString(a));
}
}
静态导入
/*
StaticImport 静态导入。
当类名重名时,需要指定具体的包名。
当方法重名是,指定具备所属的对象或者类。
*/
import java.util.Arrays;
import static java.util.Arrays.*; //导入的是Arrays这个类中的所有静态成员。
import static java.lang.System.*; // 导入了System类中所有静态成员。
public class StaticImport {
public static void main(String[] args) {
int[] arr = {1,2,3,5};
sort(arr);
int index = binarySearch(arr,5);
out.println(index); // 3
// toString(); // 报错,因为类中本来就有toString方法,引起冲突,所以需要写上类名或对象名
out.println(Arrays.toString(arr)); // [1, 2, 3, 5]
}
}
————————————————
原文链接:https://blog.csdn.net/qq_37482956/article/details/100577776
java的集合工具类Collections的更多相关文章
- java之集合工具类Collections
Collections类简介 java.utils.Collections 是集合工具类,用来对集合进行操作.此类完全由在 collection 上进行操作或返回 collection 的静态方法组成 ...
- Java:集合工具类-Collections
Java.util.Collections 集合框架工具类Collections,其方法都是静态的,本身没有构造函数. 常见方法: static <T extends Comparable< ...
- Java从零开始学二十四(集合工具类Collections)
一.Collections简介 在集合的应用开发中,集合的若干接口和若干个子类是最最常使用的,但是在JDK中提供了一种集合操作的工具类 —— Collections,可以直接通过此类方便的操作集合 二 ...
- Java笔记(二十四)……集合工具类Collections&Arrays
Collections 集合框架的工具类,方法全部为静态 Collections与Collection的区别 Collection是集合框架的一个顶层接口,里面定义了单列集合的共性方法 Collect ...
- Java常用类(五)之集合工具类Collections
前言 Java提供了一个操作Set.List和Map等集合的工具类:Collections,该工具类提供了大量方法对集合进行排序.查询和修改等操作, 还提供了将集合对象置为不可变.对集合对象实现同步控 ...
- 吴裕雄--天生自然java开发常用类库学习笔记:集合工具类Collections
import java.util.Collections ; import java.util.List ; import java.util.Set ; public class Collectio ...
- [黑马程序员] 集合框架2——Map系 & 集合工具类(Collections、Arrays)
---------------------- ASP.Net+Android+IO开发..Net培训.期待与您交流! ---------------------- 0. 集合框架按其所实现的接口, 大 ...
- Java 集合工具类---------- Collections类
- [Google Guava] 2.3-强大的集合工具类:java.util.Collections中未包含的集合工具
原文链接 译文链接 译者:沈义扬,校对:丁一 尚未完成: Queues, Tables工具类 任何对JDK集合框架有经验的程序员都熟悉和喜欢java.util.Collections包含的工具方法.G ...
随机推荐
- html使用字符串拼接js函数时传字符串参数
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...
- Java高频经典面试题(第一季)五:递归与迭代
编程题: 有n步台阶, 一次只能上 1步 或 2步, 共有多少种走法? 递归 循环迭代 递归: package will01; import org.junit.Test; public class ...
- Devops、CI\CD、Jenkins
Devops DevOps对应用程序发布的影响 在很多企业中,应用程序发布是一项涉及多个团队.压力很大.风险很高的活动.然而在具备DevOps能力的组织中,应用程序发布的风险很低,原因如下 [2] : ...
- leetcode-第14周双周赛-1273-删除树节点
题目描述: 自己的提交:动态规划 class Solution: def deleteTreeNodes(self, nodes: int, parent: List[int], value: Lis ...
- 贾扬清谈大数据&AI发展的新挑战和新机遇
摘要:2019云栖大会大数据&AI专场,阿里巴巴高级研究员贾扬清为我们带来<大数据AI发展的新机遇和新挑战>的分享.本文主要从人工智能的概念开始讲起,谈及了深度学习的发展和模型训练 ...
- loadRunner之参数关联
录制脚本,对用户名和密码进行参数化: Action() { web_url("WebTours", "URL=http://127.0.0.1:1080/WebTours ...
- python--闭包函数、装饰器
先来点补充. x= def foo(): print(x) x= foo() 结果: x= def foo(): global x x= print(x) foo() print(x) 结果: x= ...
- Delphi正则表达式使用方法(TPerlRegEx)
目前主流的delphi下的正则表达式,应该是 PerlRegEx . 官方网站: http://www.regular-expressions.info/delphi.html 直接下载: ht ...
- NOIWC2019 懵逼记
弱省蒟蒻,第一次也是最后一次来冬令营.. Day [-inf,-1] \(woc\)咋啥都听不懂,没错在下划水王. Day 0 白天上课继续划水..晚上跑去试机,骗了半天交互的分就滚了..半夜里竟然睡 ...
- 6.zabbix微信告警3.2
原文地址: https://blog.cactifans.com/2016/01/27/zabbix%E5%BE%AE%E4%BF%A1%E5%91%8A%E8%AD%A6/ pdf : 链接: ht ...