一、 Collections
针对集合操作 的工具类,里面的方法都是静态的,可以对集合进行排序、二分查找、反转、混排等。
1、Collection和Collections的区别
Collection:是单列集合的顶层接口,有子接口List和Set。Collections:是针对集合操作的工具类,有对集合进行排序和二分查找等方法
2、Collections常用方法
* 常用的方法
* public static <T> void sort(List<T> list):排序 默认情况下是自然顺序。
* public static <T> int binarySearch(List<?> list,T key):二分查找
* public static <T> T max(Collection<?> coll):最大值
* public static void reverse(List<?> list):反转
* public static void shuffle(List<?> list):随机置换
*/
public class CollectionsDemo {
public static void main(String[] args) {
// 创建集合对象
List<Integer> list = new ArrayList<Integer>();
// 添加元素
list.add(30);
list.add(20);
list.add(50);
list.add(10);
list.add(40);
System.out.println("list:" + list);
//public static void shuffle(List<?> list):随机置换
Collections.shuffle(list);
System.out.println("list:" + list);
}
}
二、 Arrays工具类
此类包含用来操作数组(比如排序和搜索)的各种方法。此类还包含一个允许将数组作为列表来查看的静态工厂。
1、常用方法
方法声明 | 功能描述 |
---|---|
Arrays.asList() | 可以从 Array 转换成 List 。可以作为其他集合类型构造器的参数 |
Arrays.binarySearch() | 在一个已排序的或者其中一段中快速查找 |
Arrays.copyOf() | 如果你想扩大数组容量又不想改变它的内容的时候可以使用这个方法 |
Arrays.copyOfRange() | 可以复制整个数组或其中的一部分 |
Arrays.deepEquals() Arrays.deepHashCode() | Arrays.equals/hashCode 的高级版本,支持子数组的操作 |
Arrays.equals() | 如果你想要比较两个数组是否相等,应该调用这个方法而不是数组对象中的 equals 方法(数组对象中没有重写equals() 方法,所以这个方法之比较引用而不比较内容)。这个方法集合了Java 5的自动装箱和无参变量的特性,来实现将一个变量快速地传给 equals() 方法——所以这个方法在比较了对象的类型之后是直接传值进去比较的 |
Arrays.fill() | 用一个给定的值填充整个数组或其中的一部分 |
Arrays.hashCode() | 用来根据数组的内容计算其哈希值(数组对象的hashCode() 不可用)。这个方法集合了Java 5的自动装箱和无参变量的特性,来实现将一个变量快速地传给 Arrays.hashcode 方法——只是传值进去,不是对象 |
Arrays.sort() | 对整个数组或者数组的一部分进行排序。也可以使用此方法用给定的比较器对对象数组进行排序 |
Arrays.toString() | 打印数组的内容 |
如果想要复制整个数组或其中一部分到另一个数组,可以调用 System.arraycopy()
方法。此方法从源数组中指定的位置复制指定个数的元素到目标数组里。这无疑是一个简便的方法。
public class Test {
public static void main(String[] args) {
System.out.println("1、将数组转成集合");
System.out.println("-------------------");
// asList()将数组转换为集合
List<Integer> list = Arrays.asList(87, 67, 65, 544);
for (Integer i : list) {
System.out.println(i);
}
System.out.println("2、二分查找");
System.out.println("-------------------");
// binarySearch()二分查找
int[] a = { 23, 45, 67, 8, 32, 45, 6, 7, 85, 54, 3, 432 };
int index = Arrays.binarySearch(a, 45);
System.out.println(index);
System.out.println("3、排序");
System.out.println("-------------------");
// sort()排序
System.out.println("排序前:" + Arrays.toString(a));
Arrays.sort(a);
System.out.println("排序后:" + Arrays.toString(a));
System.out.println("4、集合转成数组");
System.out.println("-------------------");
// toArray()集合转成数组
ArrayList<String> al = new ArrayList<String>();
al.add("java");
al.add("javase");
al.add("php");
al.add("ruby");
al.add("android");
String[] str = al.toArray(new String[al.size()]);
System.out.println(Arrays.toString(str));
}
}
Notes: 转换int类型的时候需要注意,Integer[] numbers = { 1,2,5,6,8,10,12,50,26,45,42};
List<Integer> array = Arrays.asList(numbers);
使用int[]
通不过编译。
本文都来自博客集合工具类的精简版,详细的分析参考博客