目錄

Arrays类及基本使用

主要方法

  • static type[] copyof(type[] original,int length)
  • static int binarysearch(type[] a,type key)
  • static boolean equals(type[] a,type[] b)
  • static void fill(type[] a,type val)
  • static void fill(type[] a,int fromindex,int toindex,type val)
  • static void sort(type[] a)

实例代码

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
package Arrays;

import java.text.Collator;
import java.util.Arrays;
import java.util.Comparator;

public class ArraysDemo {
	public static void main(String agrs[]) {
		Integer arr[]=new Integer[9];
		for(int i=0;i<9;i++)
			arr[i]=(int)(Math.random()*100);
		//显示,排序数组
		System.out.print("原内容:");
		display(arr);
		Arrays.sort(arr);
		System.out.print("排序后:");
		display(arr);
		//将值-1分配给数组arr中下标从0到3-1的位置
		Arrays.fill(arr, 0,3,-1);
		System.out.print("fill()后:");
		display(arr);
		//搜索23
		System.out.print("值23的位置:");
		int index =Arrays.binarySearch(arr, 23);//二分查找
		System.out.print(index);//如果查找不到,index为负
		System.out.print("\n插入0在3号位置:");
		Arrays.fill(arr,3,4,0);
		display(arr);
		System.out.print("值0的位置:");
		index =Arrays.binarySearch(arr, 0);
		System.out.print(index);
		Integer arr2[]=new Integer[8];
		arr2=Arrays.copyOf(arr, arr2.length);
		//复制8个
		System.out.print("\n复制后的数组:");
		display(arr2);
		if(Arrays.equals(arr, arr2))
			System.out.println("两数组相同!");
		else System.out.println("两数组不相同!");
		System.out.println("----------------------------------------");
		String[] str = {"计算机","黄桑","通信","李瑞豪"};
		Arrays.sort(str);
		for(int i=0;i<str.length;i++)
			System.out.print(str[i]+" ");
		System.out.println("");
		//Collator类是用来执行分语言环境的字符串比较,这里用的CHINA
		Comparator com=Collator.getInstance(java.util.Locale.CHINA);//获取Comparator对象,参数表示按中文排序
		//根据指定的 "比较器" 产生的顺序对 "指定对象数组" 进行排序
		Arrays.sort(str,com);//sort(T[] a,Comparator<?super T>c)
		for(int i=0;i<str.length;i++)
			System.out.print(str[i]+" ");
	}
	static void display(Integer arr[]) {
		for(int i=0;i<arr.length;i++)
			System.out.print(arr[i]+" ");
		System.out.println("");
	}
}

程序运行结果

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
原内容:41 0 44 96 49 96 30 6 87 
排序后:0 6 30 41 44 49 87 96 96 
fill()后:-1 -1 -1 41 44 49 87 96 96 
值23的位置:-4
插入0在3号位置:-1 -1 -1 0 44 49 87 96 96 
值0的位置:3
复制后的数组:-1 -1 -1 0 44 49 87 96 
两数组不相同!
----------------------------------------
李瑞豪 计算机 通信 黄桑 
黄桑 计算机 李瑞豪 通信