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 ...
随机推荐
- Windows下多个JDK版本之间的切换
一.JDK版本切换批处理脚本 我们平时在window上做开发的时候,可能需要同时开发两个甚至多个项目,有时不同的项目对JDK的版本要求有区别,这时候我们可能会在一台电脑上安装多个版本的JDK,如下 ...
- JavaScript中的__proto__
实例中的__proto__ 箭头函数的__proto__ 需要注意的是箭头函数的__proto__并没有指向Function构造函数的的原型对象 MDN上的资料显示,箭头函数不绑定Arguments ...
- C语言——循环队列和链队列的基本运算
// 循环队列#include <stdio.h> #include "SeqQue.h" // 循环队列的基本运算 /* const int maxsize = 20 ...
- OpenCV实现基于傅里叶变换的旋转文本校正
代码 先给出代码,再详细解释一下过程: #include <opencv2/core/core.hpp> #include <opencv2/imgproc/imgproc.hpp& ...
- Conda常用命令整理
主要参考Anaconda官方指南Using Conda:https://conda.io/docs/using/index.html 环境:Win10 64bit with conda 4.3.14 ...
- 在C#中internal、protected internal关键字是什么意思?
internal:就是程序集. 那么什么是程序集呢?就是“项目”也就是工程里中的csproj 比如:我有个解决方案,这个方案中有2个项目,1个是控制台程序,1个是webapi项目,那么我这个解决方案中 ...
- .NET的那些事儿(9)——C# 2.0 中用iTextSharp制作PDF(基础篇) .
该文主要介绍如何借助iTextSharp在C# 2.0中制作PDF文件,本文的架构大致按照iTextSharp的操作文档进行翻译,如果需要查看原文,请点击一下链接:http://itextsharp. ...
- 初始HTML
了解HTML 1.1 HTML的作用 HTML就是用来制作网页 1.2 什么是HTML HTML是英文HyperText Markup Language的首字母缩写,即超文本标 ...
- 小J学python--Exception-异常
现在我们要打开一个名为fuck的文件,fuck是不存在的,看看异常是怎么工作的 不捕获异常的情况 #打开文件 open('fuck') 执行结果 捕获所有异常 Exception是所有异常类的父类,所 ...
- 关于Class类的getResource().getPath()方法
程序中配置文件如果放置在classes文件夹,那么我们就可以使用Class类的getResource().getPath()方法获取文件路径. 例如: String path = DBUtil.cla ...