此类包含用来操作数组(比如排序和搜索)的各种方法。此类还包含一个允许将数组作为列表来查看的静态工厂。 除非特别注明,否则如果指定数组引用为 null,则此类中的方法都会抛出 NullPointerException。
获取集合
Arrays.asList() 方法,返回的是一个固定大小的数组 , 也就是说不可以进行add 和 remove 操作.
数组排序
Arrays.sort()方法,对指定的 char 型数组按数字升序进行排序。该排序算法是一个经过调优的快速排序法
二分查找
Arrays.binarySearch(数组,查找值)方法,使用二分搜索法来搜索指定的 byte 型数组,以获得指定的值。必须在进行此调用之前对数组进行排序(通过 sort(byte[]方法)。如果没有对数组进行排序,则结果是不确定的。如果数组包含多个带有指定值的元素,则无法保证找到的是哪一个。
数组比较
Arrays.equals(数组1,数组2)方法,如果两个指定的 boolean 型数组彼此相等,则返回 true。如果两个数组包含相同数量的元素,并且两个数组中的所有相应元素对都是相等的,则认为这两个数组是相等的。换句话说,如果两个数组以相同顺序包含相同的元素,则两个数组是相等的。此外,如果两个数组引用都为 null,则认为它们是相等的。
package DEMO2.DAY11_demo02_arrays;
import java.util.Arrays;
import java.util.List;
public class Demo {
public static void main(String[] args) {
//获取集合
List list = Arrays.asList(1,2,3,4);
System.out.println("将多个数据转成list集合:"+list);
//数组排序
int[] arr = {1,6,78,34,99,6,8,8};
System.out.println("排序之前:"+Arrays.toString(arr));
Arrays.sort(arr);
System.out.println("排序之后:"+Arrays.toString(arr));
//查找之前数组必须进行排序
int index = Arrays.binarySearch(arr,34);
System.out.println("查找到的:"+index);
int index2 = Arrays.binarySearch(arr,0,7,6);
System.out.println("在区间内查找:"+index2);
//数组比较
int[] arr1 = {1,2,3};
int[] arr2 = {1,3,2};
System.out.println("数组是否相等:"+Arrays.equals(arr1,arr2));
}
}