Java中的集合框架-Collections和Arrays
上一篇《Java中的集合框架-Map》把集合框架中的键值对容器Map中常用的知识记录了一下,本节记录一下集合框架的两个工具类Collections和Arrays
一,Collections
Collections类中的方法全部都是静态的,它可以对Collection和Map进行一些操作,并返回这些接口的对象或操作结果。
1,Collections的字段
Collections有三个静态字段:EMPTY_LIST,EMPTY_MAP,EMPTY_SET;这三个字段分别返回一个空的List,Map和Set并且是不可修改的,当我们试图修改这三个返回的集合容器时,会抛出java.lang.UnsupportedOperationException异常;只所以不能修改这三个返回的集合容器,原因是被返回的这三个容器都是final所修饰的。
2,Collections的方法
private static void fun_demo1() {
ArrayList list = new ArrayList();
Collections.addAll(list, "a", "b", "c");// addAll方法,将三个元素添加到list集合中
int result = Collections.binarySearch(list, "b");// 使用二分查找法查询一个元素在容器中的位置,若没有该元素则返回-1
System.out.println("二分查找元素位置:" + result);
// 返回一个类型安全的容器,相当于Collection<String> al=new ArrayList<String>();
Collection al = Collections.checkedCollection(new ArrayList(), String.class);
// checkedList,checkedSet,checkedMap与上面相同,不再操作
ArrayList list2 = new ArrayList();
Collections.addAll(list2, "d", "e", "f");
Collections.copy(list, list2);// 将一个List2中的内容复制到List中此时list中元素的长度应当大于等于list2的长度
System.out.println(list);
System.out.println(Collections.disjoint(list, list2));// 若两个容器没有相同的元素则返回true
Collections.emptyList();
Collections.emptySet();
Collections.emptyMap();// 这三个方法返回三个空的,不可添加元素的容器对象
Enumeration enumeration = Collections.enumeration(list);// 返回collection上的枚举器对象
Collections.fill(list, "555");// 使用“555”把list中的所有元素都替换掉
System.out.println(Collections.frequency(list2, "d"));// 返回list2中等于“d”的元素数量
System.out.println(Collections.indexOfSubList(list, list2));// 返回list中第一次出现list2的位置
System.out.println(Collections.lastIndexOfSubList(list, list2));// 返回list中最后一次出现list2的位置
ArrayList aList = Collections.list(enumeration);// 返回一个ArrayList,接收一个枚举器对象
System.out.println(Collections.max(list));// 返回集合中的最大元素,此方法有一个重载的版本可以接收一个自定义比较器自行指定比较的方式
System.out.println(Collections.min(list));// 返回集合中的最小元素,此方法也有一个重载可接收一个比较器
System.out.println(Collections.nCopies(3, "777"));// 返回一个由三个“777”组成的不可修改的List
System.out.println(Collections.newSetFromMap(new HashMap()));// 从Map转为Set
Collections.replaceAll(list2, "d", "33333");// 使用“33333”替换容器中的“d”
Collections.reverse(list2);// 反转容器中的元素
Collections.reverseOrder();// 返回一个比较器对象,它还可以接收一个比较器参数
Collections.rotate(list2, 1);// 根据指定距离轮换容器中的元素
System.out.println(list2);
Collections.shuffle(list2);// 使用默认随机对指定列表进行转换,此方法还可以接收一个Random随机种子
System.out.println(list2);
Collections.sort(list);// 排序,可再接收一个参数比较器对象,指定排序方式
Collections.swap(list2, 1, 2);// 交换两个指定位置的元素
System.out.println(list2);
Collections.synchronizedCollection(list);//返回一个线程安全的Collection对象
Collections.synchronizedList(list);//返回一个线程安全的List,还有synchronizedSet以及synchronizedMap
Collections.unmodifiableCollection(list);//返回一个不可修改的Collection
Collections.unmodifiableList(list);//返回一个不可修改的List,还有unmodifiableSet和unmodifiableMap
}
二,Arrays
此类包含了用来操作数组的静态方法,通过此类还可以将数组转为List来查看。若此数组为null则在调用此方法后会抛出空指针异常。具体演示如下:
1,asList(T... e)方法,将数组或数组元素转为一个不可修改的List视图
private static void fun_demo2() {
int[] arry = { 1, 2, 3, 4, 5, 6 };//
List list1 = Arrays.asList(arry);// 将数组转为List,此时List中只包含了一个元素即arry的引用,并且此List不可修改
System.out.println(list1.size());// 此时size为1
List list = Arrays.asList(1, 2, 3, 4, 5, 6);// 将数组元素转为List
System.out.println(list.size());// 此时size为6
Object[] obj = list.toArray();// 可以用Collection的toArray方法用于List和数组的互转
}
2,binarySearch方法
此方法有很多个重载的版本,可以对各种基本数据类型的数组以二分查找法查找指定值在数组中的位置,若没有该值,则返回一个负值,所返回的负值加1便是该值若存在时应该在的位置。
当此方法处理泛型时,可指定一个比较器用于对泛型元素进行比较。
public class MyComparator implements Comparator<String> {
@Override
public int compare(String o1, String o2) {
return o1.toString().compareTo(o2.toString());
}
}
private static void fun_demo3() {
int[] arry = { 1, 2, 10, 4, 23, 9 };//
int result = Arrays.binarySearch(arry, 0, arry.length, 8);// 使用二分查找法查找元素的位置,返回-3,此返回值+1便是应该在数组中的位置
System.out.println(result);
String[] str = { "abc", "adei", "zkdie", "nmkiek" };
System.out.println(Arrays.binarySearch(str, "zkdie", new MyComparator()));//使用泛型可指定一个比较器
}
3,copyof方法
此方法也有多个重载的版本,可以对各种基本数据类型的数组进行截取或扩展,当此方法的第二个参数大于原数组的长度时,它便扩展;当小于原数组的长度时它便截取。
此方法截取或扩展后返回一个原数组的副本,若是截取则从第一个元素开始;若是扩展则是在扩展位置填充该数组类型的默认值。操作如下:
private static void fun_demo4() {
int[] arry = { 1, 2, 10, 4, 23, 9 };//
arry = Arrays.copyOf(arry, 10);// 对数组进行扩展,扩展位置填充0
System.out.println(arry.length);
for (int i = 0; i < arry.length; i++) {
System.out.print(arry[i]);
System.out.print(" ");
}
arry = Arrays.copyOf(arry, 3);// 截取数组
System.out.println(arry.length);
for (int i = 0; i < arry.length; i++) {
System.out.print(arry[i]);
System.out.print(" ");
}
}
4,copyOfRange方法
此方法将指定数组的指定位置复制到一个新数组中,也有多个重载的版本,可处理各种基本类型的数组,操作如下:
private static void fun_demo5() {
int[] arry = { 1, 2, 10, 4, 23, 9 };//
arry = Arrays.copyOfRange(arry, 2, 5);//指定截取位置的复制,位置包括头不包括尾
for (int i = 0; i < arry.length; i++) {
System.out.print(arry[i]);
System.out.print(" ");
}
}
5,deepEquqls,deepHashCode和deepToString方法
这三个方法中第一个方法接收两个参数分别为两个Object类型的数组,是深度比较两个Object类型的数组是否相同,它比较的时候若此Object数组是个二维数组则会进一步比较二维数组中的内容,即深度比较。
第二个方法接收一个Object类型的数组,若此Object类型的数组是个二维数组,则对其中的元素进行相关计算后返回一个hashcode码
第三个方法也接收一个Object类型的组,返回此数组的直接字符串形式而不是一个hashCode码加上一个“[”。演示如下:
private static void fun_demo6() {
Object[] arry = { 1, 2, 10, 4, 23, 9 };//
System.out.println(arry.toString());
System.out.println(Arrays.deepToString(arry));
Object[] arry1 = { 1, 2, 10, 4, 23, 9 };//
System.out.println(Arrays.deepEquals(arry, arry1));
}
6,equals方法
此方法有多个重载的版本,也处理各种基本的数组。接收两个基本类型数组参数,如果两个参数数组相等,则返回true。
7,fill方法
此方法有多个重载的版本,能处理各种基本类型的数组。接收两个参数,第一个为需要处理的数组,第二个为替换的值。此方法的功能就是拿第二个参数把数组中的所有元素都替换掉,演示如下:
private static void fun_demo7() {
Object[] arry = { 1, 2, 10, 4, 23, 9 };//
Arrays.fill(arry, 0, 3, 0);//指定替换的位置
System.out.println(Arrays.deepToString(arry));
Arrays.fill(arry, 0);//全部替换
System.out.println(Arrays.deepToString(arry));
}
8,hashcode与toString方法
这两个方法第一个返回数组的hash值,第二个返回数组的字符串表示形式;
它与deepHashCode和deepToString方法的不同之处在于当是一维数组时hashcode与deepHashCode方法返回结果相同,二维数组返回值则不同;
deepToString方法返回数组内容的字符串表示形式,而toString方法则返回"["+数组类型的简称+数组的hashCode
private static void fun_demo8() {
Object[][] arry = new Object[5][5];
arry[0][0] = 1;
arry[0][1] = 2;
arry[0][3] = 3;
arry[1][0] = 1;
arry[1][1] = 2;
arry[1][3] = 3;
arry[2][0] = 1;
arry[2][1] = 2;
arry[2][3] = 3;
arry[3][0] = 1;
arry[3][1] = 2;
arry[3][3] = 3;
System.out.println(Arrays.deepHashCode(arry));
System.out.println(Arrays.hashCode(arry));
System.out.println(Arrays.deepToString(arry));
System.out.println(Arrays.toString(arry));
}
9,sort方法
此方法用在开发中比较多,对数组内容的排序操作,此方法没有返回值,排序后影响原来数组中的内容;默认按照升序排序,操作如下:
private static void fun_demo9() {
Object[] array = { 89, 9, 34, 2, 0, 1, -2 };
Arrays.sort(array);
System.out.println(Arrays.deepToString(array));
}
也可指定对数组中的部分元素进行排序,操作如下:
private static void fun_demo9() {
Object[] array = { 89, 9, 34, 2, 0, 1, -2 };
Arrays.sort(array, 3, 6);//指定从哪个索引开始排序到哪个索引结束排序,包括开始不包括结束
System.out.println(Arrays.deepToString(array));
}
也可以指定一个比较器对象,指定排序的方式,示例如下:
public class MyComparator implements Comparator<String> {
@Override
public int compare(String o1, String o2) {
return o2.toString().compareTo(o1.toString());
}
}
按照降序对字符串进行排序
private static void fun_demo10() {
String[] str = { "abkcie", "kdiek", "iweeoie9", "7382akbik", "kdoiw", "null" };
Arrays.sort(str, new MyComparator());
System.out.println(Arrays.deepToString(str));
}
Java中的集合框架-Collections和Arrays的更多相关文章
- Java中的集合框架(上)
Java中的集合框架概述 集合的概念: Java中的集合类:是一种工具类,就像是容器,存储任意数量的具有共同属性的对象. 集合的作用: 1.在类的内部,对数据进行组织: 2.简单的快速的搜索大数据量的 ...
- 菜鸟日记之 java中的集合框架
java中的集合框架图 如图所示:java中的集合分为两种Collection和Map两种接口 可分为Collection是单列集合和Map的双列集合 Collection单列集合:继承了Iterat ...
- Java中的集合框架-Map
前两篇<Java中的集合框架-Commection(一)>和<Java中的集合框架-Commection(二)>把集合框架中的Collection开发常用知识点作了一下记录,从 ...
- Java中的集合框架-Collection(二)
上一篇<Java中的集合框架-Collection(一)>把Java集合框架中的Collection与List及其常用实现类的功能大致记录了一下,本篇接着记录Collection的另一个子 ...
- Java中的集合框架
概念与作用 集合概念 现实生活中:很多事物凑在一起 数学中的集合:具有共同属性的事物的总体 java中的集合类:是一种工具类,就像是容器,储存任意数量的具有共同属性的对象 在编程时,常常需要集中存放多 ...
- Java中的集合框架(下)
学生选课--判断Set中课程是否存在 package com.imooc.collection; import java.util.ArrayList; import java.util.Arrays ...
- JAVA 中的集合框架
java集合框架提供了一套性能优良.使用方便的接口和类,它们位于java.util包中 一.集合与数组 数组:(可以存储基本数据类型)是用来存现对象的一种容器,但是数组的长度固定,不适合在对象数量未知 ...
- Java中的集合框架-Collection(一)
一,Collection接口 在日常的开发工作中,我们经常使用数组,但是数组是有很多的局限性的,比如:数组大小固定后不可修改,只能存储基本类型的值等等. 基于数组的这些局限性,Java框架就产生了用于 ...
- Java学习--java中的集合框架、Collection接口、list接口
与数组相比:1.数组的长度固定,而集合的长度可变2.数组只能通过下表访问元素,类型固定,而有的集合可以通过任意类型查找所映射的具体对象 java集合框架:collection(list序列,queue ...
随机推荐
- bzoj一句话题解
发现好多人都在搞这个...本人也想来试试(Solved刚到70就搞这个靠不靠谱啊喂).会更新的.嗯. 1000-1029 1000 A+B problem (这个还需要一句话吗?). 1001 狼抓兔 ...
- 有关动态规划(主要是数位DP)的一点讨论
动态规划(dynamic programming)是运筹学的一个分支,是求解决策过程(decision process)最优化的数学方法.20世纪50年代初美国数学家在研究多阶段决策过程的优化问题时, ...
- JS算法之八皇后问题(回溯法)
八皇后这个经典的算法网上有很多种思路,我学习了之后自己实现了一下,现在大概说说我的思路给大家参考一下,也算记录一下,以免以后自己忘了要重新想一遍. 八皇后问题 八皇后问题,是一个古老而著名的问题,是回 ...
- MongoDB 排序文档
sort() 方法 要在 MongoDB 中的文档进行排序,需要使用sort()方法. sort() 方法接受一个文档,其中包含的字段列表连同他们的排序顺序. 要指定排序顺序1和-1. 1用于升序排列 ...
- 微服务架构之spring cloud turbine
在前面介绍了spring cloud hystrix及其hystrix dashboard,但都是对单个项目的监控,对于一个为项目而言,必定有很多微服务,一个一个去看非常的不方便,如果有一个能集中熔断 ...
- Python套接字
1.客户端/服务器架构 什么是客户端/服务器架构?对于不同的人来说,它意味着不同的东西,这取决于你问谁以及描述的是软件还是硬件系统.在这两种情况中的任何一种下,前提都很简单:服务器就是一系列硬件或软件 ...
- leetcode Ch7-Graph Search
1. Clone Graph BFS: class Solution { public: typedef UndirectedGraphNode UGNode; UndirectedGraphNode ...
- select server
server with select #include<stdio.h> #include<sys/types.h> #include<sys/socket.h> ...
- Java代码调用存储过程和存储方法
准备一个oracle 的JDBC jar 包:ojdbc14_11g.jar 首先找到你的 oracle 安装位置,例如: 1.创建一个JDBC数据库连接工具类: package com.test.d ...
- iso、ios、osi的区别
ISO 国际标准化组织(International Organization for Standardization)简称ISO,是一个全球性的非政府组织,是国际标准化领域中一个十分重要的组织.IS ...