java数组小细节~
【摘要】 @TOC 数组创建 基本语法1动态初始化:数组类型[ ] 数组名 = new [ ]{初始化数据};2.静态初始化: 数据类型[ ] 数组名 = {初始化数据};public class Test_1 { public static void main(String[] args) { //动态初始化 int[] arr = new int[6]; ...
@TOC
数组创建
基本语法
- 1动态初始化:数组类型[ ] 数组名 = new [ ]{初始化数据};
- 2.静态初始化: 数据类型[ ] 数组名 = {初始化数据};
public class Test_1 {
public static void main(String[] args) {
//动态初始化
int[] arr = new int[6];
int[] arr1 = new int[]{1,2,3,4,5,6};
//静态初始化
int[] arr2 = {1,2,3,4,5,6};
}
}
这两种初始化方式有什么区别呢?
动态初始化只是给定数组的长度,没有初始化元素!
静态初始化在初始化的时候就给定数组的每一个元素!
我们知道C语言的数组初始化方式如下:
//数组类型 数组名[] = {};
int arr3[] = {1,2,3,4,5,6};
可以看java
保留了C语言的初始化方式!
但是我们还是建议使用java
自己的初始化方式!
因为 int []
是数组类型!
数组名.length
数组名.length
:表示数组的长度!
相当于C语言中:
//C语言
length = sizeof(arr)/sizeof(arr[0]);
//java
length = arr.length //表示数组长度!
数组使用
数组访问访问:
一个数组可以访问的有范围:[0 , arr.length-1]
public static void main(String[] args) {
int[] arr1 = new int[]{1,2,3,4,5,6};
System.out.println(arr1[6]); //越界 arr1范围:[0,5]
}
越界会报数组越界异常!
数组打印
for
循环遍历打印
int[] arr3 = {1,2,3,4,5,6};
//打印数组
//1.遍历打印
for (int i = 0; i <arr3.length; i++) {
System.out.print(arr3[i]+" ");
}
-for - each
方式打印
//2.foreach打印
int[] arr6 = new int[]{1,2,3,4,5,6 };
for (int x:arr6) {
System.out.println(x);
}
IDEA
下foreach
输入方式
使用说明
for(数组的数据类型 val:数组名){ }
这里数组的数据类型
val
可以接收每个元素的值!自己假设一个名称即可!
foreach
只能用于访问数组,不能改变数组中的元素!
Arrrays.tostring
方法打印
Arrays
类下有很多实用数组的已经写好的静态方法,可以自行学习!
数组拷贝
深拷贝: 不改变原来的数组!
浅拷贝: 会改变原来的数组!
- 深拷贝
public static void main(String[] args) {
//深拷贝
int[] arr1 = new int[]{1,2,3,4,5,6};
//使用Arrays.copyOf方法可以将数组arr1内容拷贝到arr2中
int[] arr2 = Arrays.copyOf(arr1,arr1.length);
//arr1和arr2具有不同的引用,不同的空间
System.out.println("arr1引用:"+arr1);
System.out.println("arr2引用:"+arr2);
System.out.println("arr2:"+Arrays.toString(arr2));
//改变arr2并不会影响arr1数组的内容!
for (int i = 0; i <arr2.length; i++) {
arr2[i]+=1; //arr2中的内容加一
}
System.out.println("加1后的arr2:"+Arrays.toString(arr2));
System.out.println("arr1:"+Arrays.toString(arr1));
}
运行结果
深拷贝拷贝后的数组并不会影响原来的数组,是两个不同的数组具有不同的引用!
- 浅拷贝
public class Test_1 {
public static void main(String[] args) {
//浅拷贝
int[] arr1 = new int[]{1,2,3,4,5,6};
int[] arr2 = arr1; //拷贝了arr1对象的引用给了arr2!
//arr1和arr2具有相同的引用指向同一块空间!
System.out.println("arr1引用:"+arr1);
System.out.println("arr2引用:"+arr2);
System.out.println("arr2:"+Arrays.toString(arr2));
//改变arr2的值会影响arr1数组中的值!
for (int i = 0; i < arr2.length; i++) {
arr2[i]*=2; //数组arr2中的元素扩大2倍!
}
System.out.println("扩大后的arr2:"+Arrays.toString(arr2));
System.out.println("arr1:"+Arrays.toString(arr1));
}
}
运行结果:
可以看到这里的浅拷贝拷贝后的数组改变,原来数组的也会随之改变,因为他们指向相同的空间!
二维数组
二维数组和一维数组类似!
二维数组本质上也就是一维数组, 只不过每个元素又是一个一维数组。
基本语法
数据类型[][] 数组名称 = new 数据类型 [行数][列数] { 初始化数据 };
代码示例:
public static void main(String[] args) {
int[][] arr1 = new int[][]{{1,2,3},{4,5,6},{7,8,9}};
System.out.println("打印");
for (int i = 0; i <arr1.length; i++) {
System.out.println(Arrays.toString(arr1[i]));
}
for (int[] x:arr1) {
for (int y:x) {
System.out.print(y+" ");
}
}
}
二维数组的用法和一维数组并没有明显差别, 因此我们不再赘述。
同理, 还存在 “三维数组”, “四维数组” 等更复杂的数组, 只不过出现频率都很低。
null空引用
java
中的null
空引用和C语言中的NULL
类似!
null
是一个引用但是没有存对象的地址!
public static void main(String[] args) {
int[] arr = null;
System.out.println(arr);
}
空指针异常
public static void main(String[] args) {
int[] arr = null;
for (int i = 0; i <arr.length; i++) {
System.out.println(arr[i]);
}
【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)