Collections工具类与map集合

简介:

Collections是针对List系列集合操作的一个工具类。使用TreeSet集合添加自己写的类,必须要实现Comparable接口才能够进行添加,不然就会报ClassCastException类型转换错误异常。

错误示例:

1023f2eaec09856417d51e2bbd41dd2b.png


运行结果:

73c8aec81b1d3fc606aa7cbfa25e98cd.png


正确示例:

19e0af3ea5c23cfd30af4cbc070856d9.png



Collections工具类的一些方法:

Sort排序方法:

Sort排序要比以前使用的冒泡或者其他的入门排序法效率性能都要高很多,数组操作类Arrays也有Sort方法,实际上CollectionsArrays类的Sort方法都是同一个,只不过Collections所耗的时间要短一些,冒泡排序法则效率十分差。

 

性能对比代码示例(时间单位为毫秒):

0090a3bc38dc94506084e0e9aece618e.png


运行结果:

bd2cd02422c83aa755ed96269b16db73.png



binarySearch方法:

  和String类里面的indexOf方法一样,查找某个值在集合中的下标是多少,查找到了返回出下标没有查找到则返回-1

7e94e1970d2e5dbd12ffa10bead45711.png


运行结果:

95f10e6a7b37dc550ca98156c2c94a15.png


shuffle方法:

  shuffle是混排方法,能够把集合中的元素顺序打乱:

ce846b1d4f3e3c12016ac37eb2f394c0.png


运行结果:

28ecb1267e2cd4f714f06b29b0406093.png


reverse方法:

  reverse方法是逆序方法,能够把集合中的所有元素顺序反过来:

c9fde188803f7d6efb0fc1d4022e4940.png


运行结果:

b068a701cad6c446ff1e5ea71c7960e8.png



copy方法:

  此方法是用于将一个集合里的所有元素拷贝到另一个集合中。覆盖的时候从第零个开始覆盖,根据集合的长度来覆盖到被覆盖的集合:

1517a02ca6ce79ece1994a8ed337fd0e.png


运行结果:

396138d18a144646d606be217cd880d0.png


replaceAll方法:

replaceAll方法是用于将某个集合中某个元素替换成别的元素的:

6853bf3828872d117d2833482dc581ba.png


运行结果:

ddeaacc19bc9d06f9e5b7ea513937116.png



addAll方法:

  addAll可以批量的往一个集合里添加数据,并且这些数据可以是不同类型的:

ee9bba03b81c633b13082b27b7b2c51c.png


运行结果:

c994005f3927678119cb9951a54bed79.png



maxmin方法:

  这两个方法是用于得到某个集合中最大的元素和最小的元素,元素的大小是根据ACSII码来计算的:

365b415d41768ef5b1d527bb5090a706.png


运行结果:

94eaff4d48ef9da59a2e0b6e9092d7b3.png




Map集合:

Map集合是一个双列集合,也叫键值对集合,是java.util.Map接口,是以一键一值为结构的集合。Map集合必须拿着键来操作值,Map接口下有HashMapHashtable两个集合类。前者是非线程安全的,键值可以写null,后者是带有线程安全的,键值不可以写null

 

Map集合方法:

  put添加方法,添加一个键和一个值:

5ec8334df022f53baaddf1e6a4a97c6a.png


  containsKey方法用于查找一下有没有这个键,containsValue方法用于查找一下有没有这个值,有则返回true没有则会返回false

00a77df96e0aa780ed3791017f44002d.png


 keySet方法用于拿出集合里所有的键,因为返回值是Set集合类型所以需要先存放在Set集合里,然后遍历集合将键拿出来,使用的是Hashtable则是带有排序的,使用HashMap则没有排序:

370da0932637d0090dc283870486c0d0.png


运行结果:

68521c045d67381ad998098891ba8c19.png



 values方法用于拿出集合里所有的值,需要先存放在Collection集合里,然后遍历集合将键拿出来,使用的是Hashtable则是带有排序的,使用HashMap则没有排序:

a1a28b99dcebeeaabeb958ae434236e9.png


运行结果:

c3d922a4a61f35808f25a42ddf3fecb6.png




  entrySet方法,此方法可以拿出集合中的键和值,返回出来的也是Set集合类型,需要用Set集合存放,然后利用循环使用getKeygetValue方法来获得键和值:

5b2915418fc270f271eef4c134f428a8.png


运行结果:

747e9c6117f7705701c007ac307059a7.png


for each还没出来前只能使用迭代器的拿值方式:

3f57a4349cc9784345b9c2c46ef23540.png


运行结果:

f8f957f0419702f3a12c57819a6ae94c.png


size得到集合的大小:

9954685e7bd8c14f68b76254a6413715.png


remove删除某个键的数据:

123a1829b831010736a55991498eaea1.png


get得到某个键的值:

819dfc7d783b94ba8178abfd4ddf6e95.png


clear清除数据:

073e6559e3d9115b25ce5ad56e8df24a.png


批量添加数据:

0394a39332d233f70923dec15ae4bac2.png




本文转自 ZeroOne01 51CTO博客,原文链接:http://blog.51cto.com/zero01/1976543,如需转载请自行联系原作者

相关文章
|
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`用于弱引用键,防止内存泄漏。实践使用以加深理解。
74 3
|
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()方法时需要注意的问题,旨在帮助大家在工作中更高效、更安全地使用这些技术。
35 0
|
3月前
|
存储 安全 Java
java集合框架复习----(4)Map、List、set
这篇文章是Java集合框架的复习总结,重点介绍了Map集合的特点和HashMap的使用,以及Collections工具类的使用示例,同时回顾了List、Set和Map集合的概念和特点,以及Collection工具类的作用。
java集合框架复习----(4)Map、List、set
|
3月前
|
Java
【Java集合类面试二十二】、Map和Set有什么区别?
该CSDN博客文章讨论了Map和Set的区别,但提供的内容摘要并未直接解释这两种集合类型的差异。通常,Map是一种键值对集合,提供通过键快速检索值的能力,而Set是一个不允许重复元素的集合。
|
3月前
|
算法 Java 索引
【Java集合类面试四】、 描述一下Map put的过程
这篇文章详细描述了HashMap中put操作的过程,包括首次扩容、计算索引、插入数据以及链表转红黑树和可能的再次扩容。
【Java集合类面试四】、 描述一下Map put的过程
|
3月前
|
存储
|
3月前
|
安全 Java
【Java集合类面试五】、 如何得到一个线程安全的Map?
如何得到一个线程安全的Map的方法包括:使用Collections工具类将Map包装为线程安全,使用java.util.concurrent包下的ConcurrentHashMap,以及不推荐使用性能较差的Hashtable。