0、目录
1、Arrays
- Arrays是针对数组的工具类,可以进行 排序,查找,复制填充等功能。 大大提高了开发人员的工作效率。
2、copyOfRange() 数组复制
- 与使用System.arraycopy进行数组复制类似的, Arrays提供了一个copyOfRange方法进行数组复制。
- 不同的是System.arraycopy,需要事先准备好目标数组,并分配长度。 copyOfRange 只需要源数组就就可以了,通过返回值,就能够得到目标数组了。
- 除此之外,需要注意的是 copyOfRange 的第3个参数,表示源数组的结束位置,是取不到的。
import java.util.Arrays;
public class HelloWorld {
public static void main(String[] args) {
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] + " "); // 输出打印数组b[i]
}
}
}
3、toString() 转换为字符串
-
如果要打印一个数组的内容,就需要通过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);
}
}
4、sort() 排序
- 在前面章节学习了 选择法排序 和 冒泡法排序, Arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能。
import java.util.Arrays;
public class HelloWorld {
public static void main(String[] args) {
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));
}
}
5、binarySerach() 搜索
- 查询元素出现的位置
- 需要注意的是,使用binarySearch进行查找之前,必须使用sort进行排序
- 如果数组中有多个相同的元素,查找结果是不确定的
import java.util.Arrays;
public class HelloWorld {
public static void main(String[] args) {
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));
}
}
6、equals() 判断是否相同
- 比较两个数组的内容是否一样
- 第二个数组的最后一个元素是8,和第一个数组不一样,所以比较结果是false
import java.util.Arrays;
public class HelloWorld {
public static void main(String[] args) {
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));
}
}
7、fill() 填充
使用同一个值,填充整个数组
import java.util.Arrays;
public class HelloWorld {
public static void main(String[] args) {
int a[] = new int[10];
Arrays.fill(a, 5);
System.out.println(Arrays.toString(a));
}
}
8、练习:二维数组排序
首先定义一个5X8的二维数组,然后使用随机数填充满。
借助Arrays的方法对二维数组进行排序。
参考思路:
先把二维数组使用System.arraycopy进行数组复制到一个一维数组
然后使用sort进行排序
最后再复制回到二维数组。
关于随机数
0-100的 随机整数的获取办法有多种,下面是参考办法之一:
(int) (Math.random() * 100)
Math.random() 会得到一个0-1之间的随机浮点数,然后乘以100,并强转为整型即可。
import java.util.Arrays;
public class HelloWorld {
public static void main(String[] args) {
int[][] dArray = new int[5][8]; // 定义二维数组
System.out.println("----二维数组---");
for (int i = 0; i < dArray.length ; i++) //填充数据
{
for (int j = 0; j < dArray[i].length; j++)
{
dArray[i][j] = (int)(Math.random() * 100);
}
System.out.println(Arrays.toString(dArray[i]));
}
int[] array = new int[dArray.length * dArray[0].length]; // 声明一维数组长度
for (int i = 0; i < dArray.length; i++) // 将二维数组的内容全部复制到一维数组
{
System.arraycopy(dArray[i],0,array,i*dArray[0].length,dArray[0].length);
}
Arrays.sort(array); // 一维数组排序
System.out.println("二维数组:排序后----");
for (int i = 0; i <dArray.length ; i++) { // 复制到二维数组中的每个一维数组
dArray[i] = Arrays.copyOfRange(array,i * dArray[0].length,dArray.length * (1+i));
System.out.println(Arrays.toString(dArray[i]));
}
}