Collections工具类
概念:集合工具类,定义了除了存取以外的集合常用方法。
●public static void reverse(List<?> list) //反转集合中元素的顺序
●public static void shuffle(List<?> list) //随机重置集合元素的顺序
●public static void sort(List list) //升序排序(元素类型必须实现Comparable接口)
创建集合添加基本类型元素
List<Integer> list=new ArrayList();
list.add(20);
list.add(4);
list.add(56);
list.add(34);
list.add(12);
sort排序
//sort排序
System.out.println("排序之前:"+list.toString());
Collections.sort(list);
System.out.println("排序之后:"+list.toString());
//排序之前:[20, 4, 56, 34, 12]
//排序之后:[4, 12, 20, 34, 56]
二分查找
返回要查找的数组元素下标。
//binarySearch二分查找
int i=Collections.binarySearch(list,12);
System.out.println(i);//1
copy复制
List<Integer> dest=new ArrayList();
for (int j = 0; j < list.size(); j++) {
dest.add(0);
}
Collections.copy(dest,list);//要用for循环使得被复制的数组与复制数组大小相等
System.out.println(dest.toString());
reverse反转
//reverse反转
Collections.reverse(list);
System.out.println("反转之后"+list.toString());
//反转之后[56, 34, 20, 12, 4]
shuffle打乱
//shuffle打乱
Collections.shuffle(list);
System.out.println("打乱之后"+list.toString());
//打乱之后[34, 56, 4, 12, 20]
list集合转数组
//list集合转数组
System.out.println("---list集合转数组---");
Integer[] arr=list.toArray(new Integer[8]);//[20, 12, 34, 4, 56, null, null, null]
//new Integer[0]里面0是开辟的数组长度,
//若小于集合长度则会补全至一样,若大于集合长度,则以[]里的大小为基准,其余为null
System.out.println(arr.length);
System.out.println(Arrays.toString(arr));
//[34, 56, 4, 12, 20, null, null, null]
数组转list集合
//数组转集合
System.out.println("---数组转集合---");
String[] strings={"张三","赵二","李四","王五"};
//list2是一个受限集合,不能添加和删除元素
List<String> list2 = Arrays.asList(strings);
System.out.println(list2.size());
System.out.println(list2.toString());
//[张三, 赵二, 李四, 王五]
把基本类型数组转成集合时,需要修改为包装类型。
Integer[] nums= {100, 200, 300, 400, 500};
List<Integer> list3=Arrays. asList(nums);
System. out . println(list3);
//[100, 200, 300, 400, 500]