java二维数组两种初始化方法[通俗易懂]

java二维数组两种初始化方法[通俗易懂]写这篇博客的原因是因为从大一学习c语言开始就对二维数组的声明和初始化一直没有搞懂。。。。直到学到了Java依旧搞得不是很清楚。先看一道Java的基础题这道题错误的选项是B.二维数组的初始化的两种方式看了很多网上的博客,大部分都说是三种初始化的方式,我这里将其归为两种,有不同想法的小伙伴可以留言讨论。什么是二维数组:数组是一个容器,用来存储数据的。现在数组中存…

大家好,又见面了,我是你们的朋友全栈君。

写这篇博客的原因是因为从大一学习c语言开始 就对二维数组的声明 和初始化 一直没有搞懂。。。。直到学到了Java依旧搞得不是很清楚。

先看一道Java的基础题

java二维数组两种初始化方法[通俗易懂]

这道题 错误的选项 是 B.

二维数组的初始化的两种方式

看了很多网上的博客,大部分都说是三种初始化的方式,我这里将其归为两种,有不同想法的小伙伴可以留言讨论。

什么是二维数组:

数组是一个容器,用来存储数据的。现在数组中存储的不再是int,double..的类型了,而是存储的数组。

数组中的元素还是数组,我们把它称之为数组中的数组,也就做二维数组。维度增加了一层。

简单的来说二维数组  就是元素为一维数组的数组。

 

二维数组的第一种初始化方式(静态初始化):

静态初始化:初始化时由程序员显示指定每个数组元素的初始值,由系统决定数组长度

*1-1    int k[][] = {
  
  {},{},{},{}};

int a[][] = {
  
  {1,2,3},{4,5,6},{7,8,9,10}};
int b[][] = {
  
  {},{2},{},{3,5}};
直接赋值,二维数组k内层的每一组大括号就是一个一维数组。有几对大括号那么k数组就有几个一维数组

例如二维数组a 中 有三个一维数组,第一个与第二个一维数组中数组长度为3  第三个一维数组长度为4

可以尝试输出其中具体某个一位数组的长度 
System.out.println(a[1].length);   //3
System.out.println(b[2].length);  //0

二维数组的第二种初始化方式(动态初始化):

动态初始化:初始化时程序员只指定数组长度,由系统为数组元素分配初始值。 

第二种初始化方式  int [][]k = new int[i][j];

*2-1    int [][]m = new int[3][];
*2-2    int [][]n = new int[3][2];

第二种初始化方式
对于二维数组k来说   i这个位置必须赋值,而j 这个位置 可以赋值 也可以空着不赋值。
所以就导致了2-1  与2-2  这两种不同的赋值方式。
文章后面会从内存分配的角度来赘述这2-1与2-2的区别

 

 

深入数组 

(一)定义: 
1、数组是编程语言中最常见的一种数据结构,可用于存储多个数据。 
Java的数组要求所有的数组元素具有相同的数据类型。

2、数组是一个引用数据类型,数组的变量只是一个引用,数组元素和数组变量在内存里是分开存放的。

(二)初始化

1、静态初始化:初始化时由程序员显示指定每个数组元素的初始值,由系统决定数组长度。

2、动态初始化:初始化时程序员只指定数组长度,由系统为数组元素分配初始值。

指定初始值时,系统按如下规则分配初始值:

类型  初始值
byte、short、int、long 0

float、double    0.0

char    ‘\u0000’

boolean false

类、接口、数组 null

(三)数组在内存中存储

1. 静态初始化的存储方式

int [][]a = {
  
  {},{},{}};

 

java二维数组两种初始化方法[通俗易懂]

 

 

int a[][] = {
  
  {1,2},{3,4,5},{}};

java二维数组两种初始化方法[通俗易懂]

 

 

2.动态初始化的存储方式

*2-1

*2-1    int [][]a = new int[3][];

该代码定义了一个变量为a的二维数组,这个数组变量指向了一个长度为3的的数组,
这个数组中每个元素都是一个int类型的数组,所以默认值为null

 

java二维数组两种初始化方法[通俗易懂]

 

 

 *2-2

*2-2    int [][]a = new int[3][2];

该代码定义了一个a数组变量,这个数组变量指向一个长度为3的数组, 
这个数组的元素又是一个数组类型,它们各指向对应长度为2的int[]数组, 
每个数组元素的值为0。

java二维数组两种初始化方法[通俗易懂]

以上分析的代码验证如下

public class TestArray {

	public static void main(String[] args) {
		System.out.println("**********验证 静态初始化 二维数组*****************");
		int a[][] = {
  
  {},{},{}};
		System.out.println(a);
		System.out.println(a[0]);
		System.out.println(a[1]);
		System.out.println(a[2]);
		for (int[] is : a) {
			for (int is2 : is) {
				System.out.print(is2 + " ");
			}
			System.out.println("");
		}
		//System.out.println(a[0][0]);  //Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0
		
		System.out.println("--------------------");
		int b[][] = {
  
  {1,2},{},{3,4,5}};
		System.out.println(b);
		System.out.println(b[0]);
		System.out.println(b[1]);
		System.out.println(b[2]);
		for (int[] is : b) {
			for (int is2 : is) {
				System.out.print(is2 + " ");
			}
			System.out.println("");
		}
		
		
		System.out.println("**********验证 动态初始化 二维数组*****************\"");
		System.out.println("**********2-1***********");
		int c[][] = new int[3][];
		System.out.println(c);
		System.out.println(c[0]);
		System.out.println(c[1]);
		System.out.println(c[2]);
		
		//Exception in thread "main" java.lang.NullPointerException
//		for (int[] is : c) {
//			for (int is2 : is) {
//				System.out.print(is2 + " ");
//			}
//			System.out.println("");
//		}
		
		
		System.out.println("**********2-2***********");
		int d[][] = new int[3][2];
		System.out.println(d);
		System.out.println(d[0]);
		System.out.println(d[1]);
		System.out.println(d[2]);
		for (int[] is : d) {
			for (int is2 : is) {
				System.out.print(is2 + " ");
			}
			System.out.println("");
		}
			
	}
}



输出结果如下 

**********验证 静态初始化 二维数组*****************
[[I@15db9742
[I@6d06d69c
[I@7852e922
[I@4e25154f



--------------------
[[I@70dea4e
[I@5c647e05
[I@33909752
[I@55f96302
1 2 

3 4 5 
**********验证 动态初始化 二维数组*****************"
**********2-1***********
[[I@3d4eac69
null
null
null
**********2-2***********
[[I@42a57993
[I@75b84c92
[I@6bc7c054
[I@232204a1
0 0 
0 0 
0 0 

 

https://blog.csdn.net/lxf512666/article/details/52819906

https://blog.csdn.net/qijingwang/article/details/83620602

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/132047.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 做电商网站服务器在哪里,电商网站服务器如何选择「建议收藏」

    做电商网站服务器在哪里,电商网站服务器如何选择「建议收藏」网络上的电商人数越来越多,那么现在我们做电商还有的做嘛!其实,还是有机会的,这里面有两个关键点,一是所提供的产品及服务、另一个是别人访问我们网站时的感觉,也就相关到电子商务网站网站服务器。使用电子商务网站网站服务器前提,做好网络市场环境分析网络市场的贸易方式有多种,B2B、B2C、B2G、C2C、O2O等,每位卖方都是借助这些方式使用网络工具在网络上进行产品的宣传推广,展现自家产品,提供给所需的…

    2022年9月30日
    3
  • sklearn.metrics.auc_auc值计算公式

    sklearn.metrics.auc_auc值计算公式fromsklearnimportcross_validation,metricsfromsklearnimportsvmtrain_data,train_target=load(filename)#自定义加载数据函数,返回的是训练数据的数据项和标签项train_x,test_x,train_y,test_y=cross_validation.train_test_split

    2022年10月7日
    3
  • 最长递增子序列python_求最长递增子序列并输出序列

    最长递增子序列python_求最长递增子序列并输出序列一,    最长递增子序列问题的描述设L=<a1,a2,…,an>是n个不同的实数的序列,L的递增子序列是这样一个子序列Lin=<aK1,ak2,…,akm>,其中k1<k2<…<km且aK1<ak2<…<akm。求最大的m值。二,    第一种算法:转化为LCS问题求解设序列X=<b1,b2,…,bn>是对序列L…

    2025年6月22日
    3
  • 累加和校验算法(CheckSum算法)「建议收藏」

    累加和校验算法(CheckSum算法)「建议收藏」因为外界总会对电路存在或多或少的干扰,对于数字信号,很可能导致传输的数据出现千差万别。对于很多需要传输数据的场合,尤其是一些数据可能会影响一些硬件的动作(诸如嵌入式的一些设备、机器人等),错误的数据可能会带来一些隐性风险,想想都可怕。由于本人是嵌入式相关领域的,平时玩的都是单片机,当然单片机的性能千差万别,不过很多的性能都只能说是勉强够用,毕竟成本考虑。所以今天的校验说法,比较简单,但是有…

    2025年7月28日
    4
  • Git的提交与查看差异

    Git的提交与查看差异

    2021年10月24日
    61
  • java中级面试题及答案2020_java面试题及答案2020 java最新面试题及答案2020 一

    java中级面试题及答案2020_java面试题及答案2020 java最新面试题及答案2020 一java最新面试题及答案20201.一个”.java”源文件中是否可以包括多个类(不是内部类)?有什么限制?一个“.java”源文件里面可以包含多个类,但是只允许有一java最新面试题及答案个public类,并且类名必须和文件名一致。每个编译单元只能java最新面试题及答案有一个public类。这么做的意思是,每个编译单元只能有一个公开的接口,而这个接口就由其public类来表示。你可以根据…

    2022年6月19日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号