Java 常用的Arrays函数

文章目录

Arrays

sort

java 复制代码
int[] array = new int[]{1,20,3};
Arrays.sort(array);// 1 3 20

toString

  1. 帮助数组转为字符串
java 复制代码
int[] array = new int[]{1,2,3};
System.out.println(Arrays.toString(array));
// [1,2,3]

binarySearch

  1. 二分查找
java 复制代码
int[] array = new int[]{1,2,3};
System.out.println(Arrays.binarySearch(array,2));
// 返回1下标
// 第一个参数,有序的数组array,要查找的key

equals

  1. 比较两个数组是否相同,长度,数据内容,相同数组,数组指针是否为空
  2. 返回值是boolean
java 复制代码
int[] array = new int[]{1,2,3};
int[] array1 = new int[]{1,3,2};
System.out.println(Arrays.equals(array,array1));
// false

fill

  1. fill对数组进行填充
java 复制代码
int[] array = new int[10];
Arrays.fill(array,0,3,9);// [0,3)区间填充
Arrays.fill(array,9);// 都填充为9
System.out.println(Arrays.toString(array));

数组拷贝

copyOf

  1. copyOf第一个参数是数组,第二个参数是数组的长度,返回值是一个数组
java 复制代码
int[] array1 = new int[]{1,2,3};
int[] copy = Arrays.copyOf(array1,array1.length);
// 1 2 3 
// 可以当成扩容使用,剩余空间补零
int[] copy = Arrays.copyOf(array1,array1.length*2);
// 1 2 3 0 0 0

copyOfRange

  1. 进行数组范围的拷贝
java 复制代码
int[] array1 = new int[]{1,2,3,4,5,6};
int[] copy = Arrays.copyOfRange(array1,0,3);
// 1 2 3

arraycopy

  1. 直接拷贝到copy数组中
java 复制代码
int[] array1 = new int[]{1,2,3,4,5,6};
int[] copy = new int[array1.length];
System.out.println(array1,0,copy,0,array1.length);
System.out.println(Arrays.toString(copy));
// 1 2 3 4 5 6 

取传过去的数组长度(100)和原数组长度(10)的较小值,那就是10

二维数组

定义

java 复制代码
int[][] array = new int[][]{{1,2,3},{4,5,6}};
int[][] array1 = {{1,2,3},{4,5,6}};
int[][] array2 = new int[2][3];

二维数组的每个元素都是一个一维数组

遍历

java 复制代码
for(int i = 0;i < array.length;i++){
	for(int j = 0;j < array[i].length;j++){
	       System.out.print(array[i][j] + " ");
	   }
	   System.out.println();
	}
System.out.println();

for(int[] arr : array1){
   for(int x : arr){
       System.out.print(x + " ");
   }
   System.out.println();
}

deepToString

  1. 把二维数组打印成字符串
java 复制代码
int[][] array1 = {{1,2,3},{4,5,6}};
System.out.println(Arrays.deepToString(array1));
// [[1, 2, 3], [4, 5, 6]]

空指针异常

  1. 不规则的二维数组
java 复制代码
int[][] array3 = new int[2][];

// 解决方法
array3[0] = new int[]{1,2};
array3[1] = new int[]{1,2,3};

System.out.println(array3[0]);
System.out.println(array3[1]);

for(int i = 0;i < array3.length;i++){
    for(int j = 0;j < array3[i].length;j++){
        System.out.print(array3[i][j] + " ");
    }
    System.out.println();
}



二维数组是特殊的一维数组

内存的存储机制是线性的,二维数组的每个元素又都是一个一维数组

相关推荐
祈安_38 分钟前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
皮皮林55112 小时前
拒绝写重复代码,试试这套开源的 SpringBoot 组件,效率翻倍~
java·spring boot
顺风尿一寸16 小时前
从 Java NIO poll 到 Linux 内核 poll:一次系统调用的完整旅程
java
程途知微16 小时前
JVM运行时数据区各区域作用与溢出原理
java
华仔啊19 小时前
为啥不用 MP 的 saveOrUpdateBatch?MySQL 一条 SQL 批量增改才是最优解
java·后端
xiaoye201821 小时前
Lettuce连接模型、命令执行、Pipeline 浅析
java
beata1 天前
Java基础-18:Java开发中的常用设计模式:深入解析与实战应用
java·后端
Seven971 天前
剑指offer-81、⼆叉搜索树的最近公共祖先
java
雨中飘荡的记忆2 天前
保证金系统入门到实战
java·后端
Nyarlathotep01132 天前
Java内存模型
java