Collections是针对List系列集合操作的一个工具类。使用TreeSet集合添加自己写的类,必须要实现Comparable接口才能够进行添加,不然就会报ClassCastException类型转换错误异常。
错误示例:
运行结果:
正确示例:
Collections工具类的一些方法:
Sort排序方法:
Sort排序要比以前使用的冒泡或者其他的入门排序法效率性能都要高很多,数组操作类Arrays也有Sort方法,实际上Collections和Arrays类的Sort方法都是同一个,只不过Collections所耗的时间要短一些,冒泡排序法则效率十分差。
性能对比代码示例(时间单位为毫秒):
运行结果:
binarySearch方法:
和String类里面的indexOf方法一样,查找某个值在集合中的下标是多少,查找到了返回出下标没有查找到则返回-1:
运行结果:
shuffle方法:
shuffle是混排方法,能够把集合中的元素顺序打乱:
运行结果:
reverse方法:
reverse方法是逆序方法,能够把集合中的所有元素顺序反过来:
运行结果:
copy方法:
此方法是用于将一个集合里的所有元素拷贝到另一个集合中。覆盖的时候从第零个开始覆盖,根据集合的长度来覆盖到被覆盖的集合:
运行结果:
replaceAll方法:
replaceAll方法是用于将某个集合中某个元素替换成别的元素的:
运行结果:
addAll方法:
addAll可以批量的往一个集合里添加数据,并且这些数据可以是不同类型的:
运行结果:
max与min方法:
这两个方法是用于得到某个集合中最大的元素和最小的元素,元素的大小是根据ACSII码来计算的:
运行结果:
Map集合:
Map集合是一个双列集合,也叫键值对集合,是java.util.Map接口,是以一键一值为结构的集合。Map集合必须拿着键来操作值,Map接口下有HashMap和Hashtable两个集合类。前者是非线程安全的,键值可以写null,后者是带有线程安全的,键值不可以写null。
Map集合方法:
put添加方法,添加一个键和一个值:
containsKey方法用于查找一下有没有这个键,containsValue方法用于查找一下有没有这个值,有则返回true没有则会返回false:
keySet方法用于拿出集合里所有的键,因为返回值是Set集合类型所以需要先存放在Set集合里,然后遍历集合将键拿出来,使用的是Hashtable则是带有排序的,使用HashMap则没有排序:
运行结果:
values方法用于拿出集合里所有的值,需要先存放在Collection集合里,然后遍历集合将键拿出来,使用的是Hashtable则是带有排序的,使用HashMap则没有排序:
运行结果:
entrySet方法,此方法可以拿出集合中的键和值,返回出来的也是Set集合类型,需要用Set集合存放,然后利用循环使用getKey和getValue方法来获得键和值:
运行结果:
在for each还没出来前只能使用迭代器的拿值方式:
运行结果:
size得到集合的大小:
remove删除某个键的数据:
get得到某个键的值:
clear清除数据:
批量添加数据:
本文转自 ZeroOne01 51CTO博客,原文链接:http://blog.51cto.com/zero01/1976543,如需转载请自行联系原作者