6、Arrays类
2024-10-20 16:06:40
Arrays类
Arrays里面包含了一系列静态方法,用于管理或操作数组(比如排序和搜索)
常用方法
toString 返回数组的字符串形式 Arrays.toString(arr)
Integer[] integers = {1, 20, 90};
System.out.println(Arrays.toString(integers)); //[1, 20, 90]
sort 排序(自然排序和定制排序)
Integer arr[] = {1, -1, 7, 0, 89};
//1. 因为数组是引用类型,所以通过sort排序后,会直接影响到 实参 arr
//2. sort重载的,也可以通过传入一个接口 Comparator 实现定制排序
//3. 调用 定制排序 时,传入两个参数 (1) 排序的数组arr
// (2) 实现了Comparator接口的匿名内部类,要求实现 compare方法
//4. 这里体现了接口编程的方式,看看源码,就明白
// 源码分析
// (1) Arrays.sort(arr, new Comparator()
// (2) 最终到 TimSort类 private static <T> void binarySort(T[] a, int lo, int hi, int start,
// Comparator<? super T> c)
// (3) 执行到 binarySort 方法的代码,会根据动态绑定机制 c.compare()执行我们传入的
// 匿名内部类的 compare()
// while (left < right) {
// int mid = (left + right) >>> 1;
// if (c.compare(pivot, a[mid]) < 0)
// right = mid;
// else
// left = mid + 1;
// }
// (4) new Comparator() {
// @Override
// public int compare(Object o1, Object o2) {
// Integer i1 = (Integer)o1;
// Integer i2 = (Integer)o2;
// return i2 - i1;
// }
// }
// (5) public int compare(Object o1, Object o2) 返回的值>0 还是 <0
// 会影响整个排序结果
//Arrays.sort(arr); // 默认排序
//定制排序
Arrays.sort(arr, new Comparator() {
@Override
public int compare(Object o1, Object o2) {
Integer i1 = (Integer)o1;
Integer i2 = (Integer)o2;
return i1 - i2;
}
});
System.out.println(Arrays.toString(arr));//[-1, 0, 1, 7, 89]binarySearch 通过二分搜索法进行查找,要求必须排好序
//1. 要求该数组是有序的,如果该数组是无序的,不能使用binarySearch
//2. 如果数组中不存在该元素,就返回 return -(low + 1); low是如果存在,它应该在的位置
Integer[] arr = {1, 2, 90, 123, 567};
int index = Arrays.binarySearch(arr,2);
System.out.println("index=" + index);
copyOf 数组元素的复制
//1. 从 arr 数组中,拷贝 arr.length 个元素到 newArr数组中
//2. 如果拷贝的长度 > arr.length 就在新数组的后面 增加 null
//3. 如果拷贝长度 < 0 就抛出异常NegativeArraySizeException
//4. 该方法的底层使用的是 System.arraycopy()
Integer[] newArr = Arrays.copyOf(arr,arr.length);
fill 数组元素的填充
//1. 使用 99 去填充 num数组,可以理解成是替换原来的元素
Integer[] num = new Integer[]{9, 3, 2};
Arrays.fill(num,99);
System.out.println(Arrays.toString(num)); //[99, 99, 99]
equals 比较两个元素内容是否完全一致
//1. 如果arr 和 arr2 数组的元素一样,则方法返回true
//2. 如果不是完全一样,就返回false
Boolean equals = Arrays.equals(arr,arr2);
System.out.println("equals=" + equals); //equals=true
asList 将一组值,转换成list
//1. asList方法,会将(2,3,4,5,6,1)数据转成一个List集合
//2. 返回的 asList 编译类型 List(接口)
//3. asList 运行类型 java.util.Arrays#ArrayList
List asList = Arrays.asList(2,3,4,5,6,1);
System.out.println("asList=" + asList);
System.out.println("asList的运行类型" + asList.getClass());
最新文章
- spring 配置bean
- PHP storm快捷键
- sql连接又一篇
- Selenium Grid原理
- JavaScript数组的学习
- CC2530红外学习球学码函数(P1.2接红外一体接收头,使用定时器tim1的复用功能2)
- Thinkphp交友手机首页简明前台、后台
- slf4j-logback 日志以json格式导入ELK
- ArcEngine小问题解决
- 重启部署在阿里云上的huginn
- 详解 JSONP跨域请求的实现
- Python-wxpy信息爬取发送至微信(小白级)
- shutil 模块
- Spring学习总结之高级装配
- 团队作业(HCL队)第三周—需求改进和系统分析
- SpingMVC_注解式开发_接收请求参数
- myisam和innodb 删除一条记录后,再次添加后,最大记录值
- C#+MVC+EF+LayUI框架的应用(附带源码和教程)
- OSMboxPend()
- [原创] hadoop学习笔记:重新格式化HDFS文件系统