JAVA数组操作的常用工具
2012/8/8 11:13:00 人气 727 怀旧国机论坛Java提供了的Arrays类里包含了一些static修饰方法可以直接操作数组,这个Arrays类里包含了提供了如下几个static修饰的方法(static修饰的方法可以直接通过类名调用):
int binarySearch(type** a,type key) :这个方法查询key元素值在a数组中出现的索引;如果a数组不包含key元素值,则返回-1.调用该方法时要求数组中元素已经按升序排列,这样才能得到正确结果。
binarySearch(type** a,intfromIndex,int toIndex,type key) :这个方法与前一个方法类似,但它只搜索a数组中formIndex到toIndex索引的元素。调用该方法时要求数组中元素已经按升序排列,这样才能得到正确结果。
type** copyOf(type** original,int newLength) :这个方法将会把original数组复制成一个新数组,其中length是新数组的长度。如果length小于original数组的长度,则新数组就是原数组的前面length个元素;如果length大于original数组的长度,则新数组的前面元素就是原数组的所个元素,后面补充0(数值型)、false(布尔型)或者null(引用型)。
type** copyOfRange(type** original,int from,int to) :这个方法与前面方法相似,但这个方法只复制original数组的from索引到to索引的元素。
boolean equals(type** a,type** a2) :如果a数组和a2数组的长度相等,而且a数组和a2数组的数组元素也一一相同,该方法将返回true.
void fill(type** a,type val) :该方法将会把a数组所有元素值都赋值为val.
void fill(type** a,int fromIndex, int toIndex, type val) :该方法与前一个方法的作用相同,区别只是该方法仅仅将a数组的fromIndex到toIndex索引的数组元素赋值为val.
void sort(type** a) :该方法对a数组的数组元素进行排序。
void sort(type** a,int fromIndex,int toIndex) :该方法与前一个方法相似,区别是该方法仅仅对fromIndex到toIndex索引的元素进行排序。
String toString(type** a):该方法将会一个数组转换成一个字符串。该方法按顺序把多个数组元素连缀在一起,多个数组元素使用英文逗号(,)和空格隔开。(利用该方法可以很清楚地看到各数组元素)
下面程序示范了Arrays类的用法:public class TestArrays
{public static void main(String** args){//定义一个a数组int** a = new int**{3, 4 , 5, 6};//定义一个a2数组int** a2 = new int**{3, 4 , 5, 6};//a数组和a2数组的长度相等,每个元素依次相等,将输出trueSystem.out.println(“a数组和a2数组是否相等:“ + Arrays.equals(a , a2));//通过复制a数组,生成一个新的b数组int** b = Arrays.copyOf(a, 6);System.out.println(“a数组和b数组是否相等:“ + Arrays.equals(a , b));//输出b数组的元素,将输出*3, 4, 5, 6, 0, 0*System.out.println(“b数组的元素为:“ + Arrays.toString(b));//将b数组的第3个元素(包括)到第5个元素(不包括)赋为1Arrays.fill(b , 2, 4 , 1); //fill方法可一次对多个数组元素进行批量赋值//输出b数组的元素,将输出*3, 4, 1, 1, 0, 0*System.out.println(“b数组的元素为:“ + Arrays.toString(b));//对b数组进行排序Arrays.sort(b);//输出b数组的元素,将输出*0, 0, 1, 1, 3, 4*System.out.println(“b数组的元素为:“ + Arrays.toString(b));}}
。
沙发 | 【Hacker〉顶帖组、小乞丐08-08 11:14 【Hacker〉顶帖组为你顶帖 加入【Hacker〉顶帖组吧! |
发表回复