写在之前:
首先,Arrays是针对数组的工具类,可以进行 排序,查找,复制填充等功能。 大大提高了开发人员的工作效率。
整一个类所涉及的关键字:
copyOfRange 数组复制
toString() 转换为字符串
sort 排序
binarySearch 搜索
equals 判断是否相同
fill 填充
数组复制:
与使用System.arraycopy进行数组复制类似的, Arrays提供了一个copyOfRange方法进行数组复制。
不同的是System.arraycopy,需要事先准备好目标数组,并分配长度。 copyOfRange 只需要源数组就就可以了,通过返回值,就能够得到目标数组了。
除此之外,需要注意的是 copyOfRange 的第3个参数,表示源数组的结束位置,是取不到的。
copyOfRange 比System.arraycopy方便一点 但是两者都得会
部分拓展:
在引用类的时候 都要预先其声明 示例以下:
import java.util.Arrays;
亦如之前要进行写入的时候也是这样的写法格式,只是些许不同。
import java.util.Scanner;
不难发现之后的声明写法格式差不多相同
copyOfRange 应用举例:
int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
// copyOfRange(int[] original, int from, int to)
// 第一个参数表示源数组
// 第二个参数表示开始位置(取得到)
// 第三个参数表示结束位置(取不到)
int[] b = Arrays.copyOfRange(a, 0, 3);
for (int i = 0; i < b.length; i++) {
System.out.print(b[i] + " ");
}
转换为字符串:
如果要打印一个数组的内容,就需要通过for循环来挨个遍历,逐一打印
但是Arrays提供了一个toString()方法,直接把一个数组,转换为字符串,这样方便观察数组的内容
应用示例:
import java.util.Arrays;
public class HelloWorld {
public static void main(String[] args) {
int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
String content = Arrays.toString(a);
System.out.println(content);
}
}
排序:
学习了 选择法排序 和 冒泡法排序,Arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能。
简便了很多。。。
int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
System.out.println("排序之前 :");
System.out.println(Arrays.toString(a));
Arrays.sort(a);
System.out.println("排序之后:");
System.out.println(Arrays.toString(a));
就不用再for循环 来写一长串代码 不过基本的排序算法得熟练。
搜索:
值得注意的是 有了相应的排序 序列才便于搜索
也就是:查询元素出现的位置
使用binarySearch进行查找之前,必须使用sort进行排序
如果数组中有多个相同的元素,查找结果是不确定的
int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
Arrays.sort(a);
System.out.println(Arrays.toString(a));
//使用binarySearch之前,必须先使用sort进行排序
System.out.println("数字 62出现的位置:"+Arrays.binarySearch(a, 62));
判断两个数组是否相同
所用到的方法是equals
int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
int b[] = new int[] { 18, 62, 68, 82, 65, 8 };
System.out.println(Arrays.equals(a, b));
最后的 9 和 8不一样。
填充
使用同一个值,填充整个数组
所用到 方法是fill
示例:
int a[] = new int[10];
Arrays.fill(a, 5);
Arrays.fill(原数组名,所填充的数字);
fill这个方法很有意思的是 不管你的数组初始化了数据中途引用这个方法 整个数组会被所填充的目标数字填充满。