集合框架之Map集合(下)

简介: 集合框架之Map集合(下)

三、集合框架工具类Arrays和Collections

1.Arrays的常用的方法

常用的方法

1.排序方法

Arrays.sort()方法可以对数组进行排序,该方法有两种重载形式,一种是按升序排序,一种是按照指定Comparator排序。

int[] arr = {5,3,7,1,9};
Arrays.sort(arr);
System.out.println(Arrays.toString(arr)); //[1, 3, 5, 7, 9]

2.查找方法

Arrays中提供了两个查找方法,一个是线性查找Arrays.binarySearch(),一个是二分查找Arrays.binarySearch()。

int[] arr = {1, 2, 3, 4, 5};
int index = Arrays.binarySearch(arr, 3);
System.out.println(index);  // 2

3.比较方法

Arrays类提供了equals和deepEquals两个用于比较数组的方法,其中deepEquals方法可以比较多维数组。

int[] arr1 = {1, 2, 3};
int[] arr2 = {1, 2, 3};
boolean result1 = Arrays.equals(arr1, arr2); // true
int[][] arr3 = {{1, 2, 3}, {4, 5, 6}};
int[][] arr4 = {{1, 2, 3}, {4, 5, 6}};
boolean result2 = Arrays.deepEquals(arr3, arr4); // true

4.复制方法

数组复制方法clone和copyOf

int[] arr1 = {1, 2, 3};
int[] arr2 = arr1.clone();
int[] arr3 = Arrays.copyOf(arr1, arr1.length);

5.填充方法

用Arrays.fill()方法可以为数组赋值。

int[] arr = new int[5];
Arrays.fill(arr, 5);
System.out.println(Arrays.toString(arr)); //[5, 5, 5, 5, 5]

2.Collections的常用的方法

常见方法

1.排序方法

sort(List<T> list)该方法用于对指定的List进行排序,使用默认的升序排序。

List<String> list = new ArrayList<>();
list.add("c");
list.add("a");
list.add("b");
Collections.sort(list); // 对list进行升序排序
System.out.println(list); // 输出 [a, b, c]

2.反转输出

reverse(List<T> list)该方法用于将指定的列表进行反转。

List<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
Collections.reverse(list); // 反转list
System.out.println(list); // 输出 [c, b, a]

3.随机排序

shuffle(List<T> list)该方法用于将指定的列表进行随机排序。

List<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
Collections.shuffle(list); // 随机排序
System.out.println(list); // 输出 [c, a, b]

4.根据有序列表查询指定元素

binarySearch(List<? extends Comparable<? super T>> list, T key)该方法用于在指定的有序列表中查找指定的元素。

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 7);
int index = Collections.binarySearch(list, 3); // 在有序列表中查找元素
System.out.println(index); // 输出 2

5.获取集合中最大的元素

max(Collection<? extends T> coll)该方法用于获取指定集合中最大的元素,根据元素的自然顺序来确定最大元素。集合中的元素必须实现Comparable接口才能进行比较。

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 7);
int max = Collections.max(list); // 获取列表中最大的元素
System.out.println(max); // 输出 7

6.获取集合中最小的元素

min(Collection<? extends T> coll)该方法用于获取指定集合中最小的元素,根据元素的自然顺序来确定最小元素。集合中的元素必须实现Comparable接口才能进行比较。

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 7);
int min = Collections.min(list); // 获取列表中最小的元素
System.out.println(min); // 输出 1

7.将源列表元素复制到目标列表

copy(List<? super T> dest, List<? extends T> src)该方法用于将源列表中的元素复制到目标列表中。

List<String> srcList = Arrays.asList("a", "b", "c");
List<String> destList = new ArrayList<>(Collections.nCopies(srcList.size(), ""));
Collections.copy(destList, srcList); // 复制srcList中的元素到destList中
System.out.println(destList); // 输出 [a, b, c]

8.返回一个不可修改的包含n个元素的列表

nCopies(int n, T o)该方法用于返回一个不可修改的包含n个元素的列表,其中所有元素都等于指定的对象。

List<String> list = Collections.nCopies(3, "a"); // 返回不可修改的列表,其中所有元素都等于"a"
System.out.println(list); // 输出 [a, a, a]

9.用指定的元素替换指定列表中的所有元素

fill(List<? super T> list, T obj)该方法用于用指定的元素替换指定列表中的所有元素。

List<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
Collections.fill(list, "d"); // 使用"d"替换所有元素
System.out.println(list); // 输出 [d, d, d]

10.用于返回集合中指定元素的出现次数

frequency(Collection<?> c, Object o)该方法用于返回集合中指定元素的出现次数。

List<Integer> list = Arrays.asList(1, 2, 1, 3, 1, 4, 1, 5);
int frequency = Collections.frequency(list, 1);
System.out.println("1出现的次数:" + frequency);

3.Arrays和Collections的区别

1.实现方式不同

Arrays 是 Java 标准类库中的一员,它提供了一个用于操作数组的工具类,其中包含了很多用于数组处理的静态方法。

Collections 是 Java 集合框架中的一员,它是一个用于操作集合类的工具类,其中包含了很多用于集合处理的静态方法。

2.所处理的对象不同

Arrays 只能处理数组类型的数据,例如 int[]String[] 等。

Collections 可以处理任意类型的集合对象,例如 ListSetMapQueue 等。

3.内容可变性不同

Arrays 中的数组长度是固定的,一旦创建就不能再改变大小。如果需要增加或删除元素,则需要重新创建数组。

Collections 中的集合内容是可变的,可以实时增删元素,因此更加灵活。

4.初始容量设置方式不同

使用 Arrays 创建数组时,必须指定数组的长度,否则会抛出 NullPointerException 异常。

使用 Collections 创建集合时不需要指定初始容量,因为它可以根据实际需要进行动态扩展。

5.线程安全性不同

ArraysCollections 都不是线程安全的类。

如果需要在多线程环境下操作集合对象,应该使用线程安全的集合类,例如 ConcurrentHashMapCopyOnWriteArrayList 等。

至此,这篇关于Map集合的一点略见就到这里啦,看在博主这么辛苦的份上就点个赞再走吧!!


相关文章
|
2月前
|
Go 定位技术 索引
Go 语言Map(集合) | 19
Go 语言Map(集合) | 19
|
2月前
|
存储 前端开发 API
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
该文章详细介绍了ES6中Set和Map数据结构的特性和使用方法,并探讨了它们在前端开发中的具体应用,包括如何利用这些数据结构来解决常见的编程问题。
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
|
1月前
|
存储 分布式计算 Java
Stream很好,Map很酷,但答应我别用toMap():Java开发中的高效集合操作
在Java的世界里,Stream API和Map集合无疑是两大强大的工具,它们极大地简化了数据处理和集合操作的复杂度。然而,在享受这些便利的同时,我们也应当警惕一些潜在的陷阱,尤其是当Stream与Map结合使用时。本文将深入探讨Stream与Map的优雅用法,并特别指出在使用toMap()方法时需要注意的问题,旨在帮助大家在工作中更高效、更安全地使用这些技术。
42 0
|
3月前
|
Java
【Java集合类面试二十二】、Map和Set有什么区别?
该CSDN博客文章讨论了Map和Set的区别,但提供的内容摘要并未直接解释这两种集合类型的差异。通常,Map是一种键值对集合,提供通过键快速检索值的能力,而Set是一个不允许重复元素的集合。
|
3月前
|
安全 Java
【Java集合类面试五】、 如何得到一个线程安全的Map?
如何得到一个线程安全的Map的方法包括:使用Collections工具类将Map包装为线程安全,使用java.util.concurrent包下的ConcurrentHashMap,以及不推荐使用性能较差的Hashtable。
|
5月前
|
Dart
Dart之集合详解(List、Set、Map)
Dart之集合详解(List、Set、Map)
|
5月前
|
存储 JavaScript 前端开发
JavaScript进阶-Map与Set集合
【6月更文挑战第20天】JavaScript的ES6引入了`Map`和`Set`,它们是高效处理集合数据的工具。`Map`允许任何类型的键,提供唯一键值对;`Set`存储唯一值。使用`Map`时,注意键可以非字符串,用`has`检查键存在。`Set`常用于数组去重,如`[...new Set(array)]`。了解它们的高级应用,如结构转换和高效查询,能提升代码质量。别忘了`WeakMap`用于弱引用键,防止内存泄漏。实践使用以加深理解。
78 3
|
3月前
|
存储 安全 Java
java集合框架复习----(4)Map、List、set
这篇文章是Java集合框架的复习总结,重点介绍了Map集合的特点和HashMap的使用,以及Collections工具类的使用示例,同时回顾了List、Set和Map集合的概念和特点,以及Collection工具类的作用。
java集合框架复习----(4)Map、List、set
|
3月前
|
算法 Java 索引
【Java集合类面试四】、 描述一下Map put的过程
这篇文章详细描述了HashMap中put操作的过程,包括首次扩容、计算索引、插入数据以及链表转红黑树和可能的再次扩容。
【Java集合类面试四】、 描述一下Map put的过程
|
3月前
|
存储