JDK提供的Arrays的几个减少重复造轮子的方法
来源:互联网 发布:青山软件破解版 编辑:程序博客网 时间:2024/06/04 18:20
前两周学习了Java的数组,了解到Java有ArrayList类有很多方法可以直接调用,ArrayList是继承自Arrays类的,这里就简单介绍几个他可以直接调用的方法吧
一、数组复制
与使用System.arraycopy进行数组复制类似的,Arrays提供了一个copyOfRange方法进行数组复制。
不同的是System.arraycopy,需要事先准备好目标数组,并分配长度。 copyOfRange只需要源数组就就可以了,通过返回值,就能够得到目标数组了。
除此之外,需要注意的是copyOfRange的第3个参数,表示源数组的结束位置,是取不到的。
importjava.util.Arrays;
publicclassHelloWorld {
publicstaticvoidmain(String[] args) {
inta[] = newint[] {18,62,68,82,65,9};
// copyOfRange(int[] original, int from, int to)
//第一个参数表示源数组
//第二个参数表示开始位置(取得到)
//第三个参数表示结束位置(取不到)
int[] b = Arrays.copyOfRange(a,0, 3);
for(inti = 0; i < b.length; i++) {
System.out.print(b[i] + " ");
}
}
}
二、转换为字符串
如果要打印一个数组的内容,就需要通过for循环来挨个遍历,逐一打印
但是Arrays提供了一个toString()方法,直接把一个数组,转换为字符串,这样方便观察数组的内容
importjava.util.Arrays;
publicclassHelloWorld {
publicstaticvoidmain(String[] args) {
inta[] = newint[] {18,62,68,82,65,9};
String content = Arrays.toString(a);
System.out.println(content);
}
}
三、排序
在前面学习了 选择法排序 和 冒泡法排序,Arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能。
importjava.util.Arrays;
publicclassHelloWorld {
publicstaticvoidmain(String[] args) {
inta[] = newint[] {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));
}
}
四、搜索
查询元素出现的位置
需要注意的是,使用binarySearch进行查找之前,必须使用sort进行排序
如果数组中有多个相同的元素,查找结果是不确定的
importjava.util.Arrays;
publicclassHelloWorld {
publicstaticvoidmain(String[] args) {
inta[] = newint[] {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));
}
}
五、判断是否相同
比较两个数组的内容是否一样
第二个数组的最后一个元素是8,和第一个数组不一样,所以比较结果是false
importjava.util.Arrays;
publicclassHelloWorld {
publicstaticvoidmain(String[] args) {
inta[] = newint[] {18,62,68,82,65,9};
intb[] = newint[] {18,62,68,82,65,8};
System.out.println(Arrays.equals(a, b));
}
}
六、填充
使用同一个值,填充整个数组
importjava.util.Arrays;
publicclassHelloWorld {
publicstaticvoidmain(String[] args) {
inta[] = newint[10];
Arrays.fill(a, 5);
System.out.println(Arrays.toString(a));
}
}
- JDK提供的Arrays的几个减少重复造轮子的方法
- 重复造轮子的目的
- 重复的轮子RTOS
- 用不同的语言重复造轮子
- 重复造轮子:注释的使用
- 关于不要重复造轮子的二三事
- 关于不要重复造轮子的二三事
- 论apache重复造的轮子
- 关于不要重复造轮子的二三事
- 减少前端代码耦合的几个方法
- 减少重复的代码
- 几个常用的JAVA类(坚持“不要重复发明轮子”的原则,留着重用)
- 重复造轮子--IOC容器的AOP简单实现
- 重复造轮子之基于nodejs的聊天室
- 关于重复造轮子的一些延续思考
- C++编程 - 真的不要重复造轮子吗
- 重复造轮子-更方便的Apk反编译
- Nginx为什么要造重复的轮子nginScript
- Pillow学习之ImageColor
- JDK(1.6,1.7,1.8)64位解压版配置使用
- 软件方法--愿景
- Pillow学习之ImageDraw
- 数学常识汇总
- JDK提供的Arrays的几个减少重复造轮子的方法
- Makefile常用函数
- Pillow学习之ImageEnhance
- 【codeforces 782D】 Innokenty and a Football League
- 深入理解java线程池
- ROS总结——创建ROS工作空间
- Pillow学习之ImageFilter
- HRBUST1212-乘积最大
- jQuery选择器总结