java.util.Arrays 类包含一个静态的工厂,允许数组被视为列表。以下是关于数组的要点:
- 这个类包含了各种方法来操作数组(比如排序和搜索)。
- 在这个类中的方法抛出NullPointerException如果指定数组引用为null。
类声明
以下是java.util.Arrays类的声明:
public class Arrays extends Object
类方法
S.N. | 方法 & 描述 |
1 | static <T> List<T> asList(T a) |
2 | static int binarySearch(byte[] a, byte key) |
3 | static int binarySearch(byte[] a, int fromIndex, int toIndex, byte key) |
4 | static int binarySearch(char[] a, char key) |
5 | static int binarySearch(char[] a, int fromIndex, int toIndex, char key) |
6 | static int binarySearch(double[] a, double key) |
7 | static int binarySearch(double[] a, int fromIndex, int toIndex, double key) |
8 | static int binarySearch(float[] a, float key) |
9 | static int binarySearch(float[] a, int fromIndex, int toIndex, float key) |
10 | static int binarySearch(int[] a, int key) |
11 | static int binarySearch(int[] a, int fromIndex, int toIndex, int key) |
12 | static int binarySearch(long[] a, int fromIndex, int toIndex, long key) |
13 | static int binarySearch(long[] a, long key) |
14 | static int binarySearch(Object[] a, int fromIndex, int toIndex, Object key) |
15 | static int binarySearch(Object[] a, Object key) |
16 | static int binarySearch(short[] a, int fromIndex, int toIndex, short key) |
17 | static int binarySearch(short[] a, short key) |
18 | static <T> int binarySearch(T[] a, int fromIndex, int toIndex, T key, Comparator<? super T> c) |
19 | static <T> int binarySearch(T[] a, T key, Comparator<? super T> c) |
20 | static boolean[] copyOf(boolean[] original, int newLength) |
21 | static byte[] copyOf(byte[] original, int newLength) |
22 | static char[] copyOf(char[] original, int newLength) |
23 | static double[] copyOf(double[] original, int newLength) |
24 | static float[] copyOf(float[] original, int newLength) |
25 | static int[] copyOf(int[] original, int newLength) |
26 | static long[] copyOf(long[] original, int newLength) |
27 | static short[] copyOf(short[] original, int newLength) |
28 | static <T> T[] copyOf(T[] original, int newLength) |
29 | static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType) |
30 | static boolean[] copyOfRange(boolean[] original, int from, int to) |
31 | static byte[] copyOfRange(byte[] original, int from, int to) |
32 | static char[] copyOfRange(char[] original, int from, int to) |
33 | static double[] copyOfRange(double[] original, int from, int to) |
34 | static float[] copyOfRange(float[] original, int from, int to) |
35 | static int[] copyOfRange(int[] original, int from, int to) |
36 | static long[] copyOfRange(long[] original, int from, int to) |
37 | static short[] copyOfRange(short[] original, int from, int to) |
38 | static <T> T[] copyOfRange(T[] original, int from, int to) |
39 | static <T,U> T[] copyOfRange(U[] original, int from, int to, Class<? extends T[]> newType) |
40 | static boolean deepEquals(Object[] a1, Object[] a2) |
41 | static int deepHashCode(Object[] a) |
42 | static String deepToString(Object[] a) |
43 | static boolean equals(boolean[] a, boolean[] a2) |
44 | static boolean equals(byte[] a, byte[] a2) |
45 | static boolean equals(char[] a, char[] a2) |
46 | static boolean equals(double[] a, double[] a2) |
47 | static boolean equals(float[] a, float[] a2) |
48 | static boolean equals(int[] a, int[] a2) |
49 | static boolean equals(long[] a, long[] a2) |
50 | static boolean equals(Object[] a, Object[] a2) |
51 | static boolean equals(short[] a, short[] a2) |
52 | static void fill(boolean[] a, boolean val) |
53 | static void fill(boolean[] a, int fromIndex, int toIndex, boolean val) |
54 | static void fill(byte[] a, byte val) |
55 | static void fill(byte[] a, int fromIndex, int toIndex, byte val) |
56 | static void fill(char[] a, char val) |
57 | static void fill(char[] a, int fromIndex, int toIndex, char val) |
58 | static void fill(double[] a, double val) |
59 | static void fill(double[] a, int fromIndex, int toIndex, double val) |
60 | static void fill(float[] a, float val) |
61 | static void fill(float[] a, int fromIndex, int toIndex, float val) |
62 | static void fill(int[] a, int val) |
63 | static void fill(int[] a, int fromIndex, int toIndex, int val) |
64 | static void fill(long[] a, int fromIndex, int toIndex, long val) |
65 | static void fill(long[] a, long val) |
66 | static void fill(Object[] a, int fromIndex, int toIndex, Object val) |
67 | static void fill(Object[] a, Object val) |
68 | static void fill(short[] a, int fromIndex, int toIndex, short val) |
69 | static void fill(short[] a, short val) |
70 | static int hashCode(boolean[] a) |
71 | static int hashCode(byte[] a) |
72 | static int hashCode(char[] a) |
73 | static int hashCode(double[] a) |
74 | static int hashCode(float[] a) |
75 | static int hashCode(int[] a) |
76 | static int hashCode(long[] a) |
77 | static int hashCode(Object[] a) |
78 | static int hashCode(short[] a) |
79 | static void sort(byte[] a) |
80 | static void sort(byte[] a, int fromIndex, int toIndex) |
81 | static void sort(char[] a) |
82 | static void sort(char[] a, int fromIndex, int toIndex) |
83 | static void sort(double[] a) |
84 | static void sort(double[] a, int fromIndex, int toIndex) |
85 | static void sort(float[] a) |
86 | static void sort(float[] a, int fromIndex, int toIndex) |
87 | static void sort(int[] a) |
88 | static void sort(int[] a, int fromIndex, int toIndex) |
89 | static void sort(long[] a) |
90 | static void sort(long[] a, int fromIndex, int toIndex) |
91 | static void sort(Object[] a) |
92 | static void sort(Object[] a, int fromIndex, int toIndex) |
93 | static void sort(short[] a) |
94 | static void sort(short[] a, int fromIndex, int toIndex) |
95 | static <T> void sort(T[] a, Comparator<? super T> c) |
96 | static <T> void sort(T[] a, int fromIndex, int toIndex, Comparator<? super T> c) |
97 | static String toString(boolean[] a) |
98 | static String toString(byte[] a) |
99 | static String toString(char[] a) |
100 | static String toString(double[] a) |
101 | static String toString(float[] a) |
102 | static String toString(int[] a) |
103 | static String toString(long[] a) |
104 | static String toString(Object[] a) |
105 | static String toString(short[] a) |
方法继承
这个类从以下类继承的方法:
- java.util.Object
//原文出自【易百教程】,商业转载请联系作者获得授权,非商业转载请保留原文链接:
数组基本概念
数组指的是一组相关变量的集合,Java 语言中提供的数组是用来存储固定大小的同类型元素。
数组的元素类型和大小都是确定的。
数组的 申明
首先必须声明数组变量,才能在程序中使用数组。下面是声明数组变量的语法:
dataType[] arrayRefVar; // 首选的方法
或
dataType arrayRefVar[]; // 效果相同,但不是首选方法
注意: 建议使用 dataType[] arrayRefVar 的声明风格声明数组变量。 dataType arrayRefVar[] 风格是来自 C/C++ 语言 ,在Java中采用是为了让 C/C++ 程序员能够快速理解java语言。
下面是这两种语法的示例:
double[] myList; // 首选的方法
或
double myList[]; // 效果相同,但不是首选方法
创建数据
Java语言使用new操作符来创建数组,语法如下:
arrayRefVar = new dataType[arraySize];
上面的语法语句做了两件事:
- 使用 dataType[arraySize] 创建了一个数组。
- 把新创建的数组的引用赋值给变量 arrayRefVar。
数组变量的声明,和创建数组可以用一条语句完成,如下所示:
//动态初始化
dataType[] arrayRefVar = new dataType[arraySize];
另外,还可以使用如下的方式创建数组。
//静态初始化,简化格式
dataType[] arrayRefVar = {value0, value1, ..., valuek};
//静态初始化,完整格式
dataType[] arrayRefVar = new dataType[]{value0, value1, ..., valuek};
数组的元素是通过索引访问的。数组索引从 0 开始,所以索引值从 0 到 arrayRefVar.length-1。
使用 new 方式创建的数组,其内容为对应数据类型的默认值。
数组也属于引用数据类型,数组与对象的唯一区别在于:对象中的堆内存保存的是该对象的属性,而数组中的堆内存保存的是其对应的一组信息,包含索引与对应的值。
多维数组
多维数组可以看成是数组的数组,比如二维数组就是一个特殊的一维数组,其每一个元素都是一个一维数组,例如:
String str[][] = new String[3][4];
多维数组的动态初始化(以二维数组为例)
- 直接为每一维分配空间,格式如下:
dataType[][] arrayName = new type[arraylenght1][arraylenght2];
dataType 可以为基本数据类型和复合数据类型,arraylenght1 和arraylenght2 必须为正整数,arraylenght1 为行数,arraylenght2 为列数。
例如:
int a[][] = new int[2][3];
数组的引用传递
数组作为引用类型,将数组作为参数传递的其他函数中,在这个函数中对数组的修改一定会影响到原始数据。
数组的操作方法
java针对数据提供了一些类库支持。
数组拷贝
System.arraycopy()方法,函数原型是:
public static void arraycopy(Object src,
int srcPos,
Object dest,
int destPos,
int length)