一、数组的两种初始化方式 1.完整格式(静态初始化) 数据类型[] 数组名 = new 数据类型[]{元素1,元素2…}; //范例int[] arr = new int[]{1,2,3,4}; 简化书写 一般我们会省略=后面的
数据类型[] 数组名 = new 数据类型[]{元素1,元素2…};
//范例int[] arr = new int[]{1,2,3,4};
简化书写
一般我们会省略=后面的 new 数据类型[]
int[] arr = {1,2,3,4};
当不知道数组里面的初始值的时候,我们就要采用动态初始化
//申请一个长度为10的int类型的数组int[] arr = new int[10];
区别:
动态初始化的数组有初始值
整数 -> 0 浮点数 -> 0.0 引用数据类型 -> null
布尔 -> false 字符型 -> 0
静态初始化不带长度,(自动计算)
通过索引循环遍历
int[] arr = {1,2,3,4};for(int i = 0; i
当然还有别的方法,我们先混个眼熟
//增强for,对于数组来说,本质与普通for相同for (int i : arr) { System.out.println(i);}//以字符串的形式展示System.out.println(Arrays.toString(arr));
开辟:在堆上开辟一块新空间,将地址返回给数组名
访问:数组名[索引]
System.out.println(arr)打印的就是arr的地址值,因为地址也是一个数嘛 printf就是负责打印
定义数组是通过new关键字,new关键字定义的所有对象都是在堆上开辟空间的
所以下面的结果是什么 是true还是false
int[] arr1 = {1,2,3}; int[] arr2 = {1,2,3};
arr1 == arr2 // true or false ???
比较的是地址值为false
虽然java弱化了指针与地址的概念,但是C的内存机制是最基础最底层的原理
数组长度为0 是指定义了一个长度为0的数组
数组 == null是指数组的地址为null,也就是空指针
从内存的角度理解数组越界的概念
栈:方法运行会加载进栈,局部变量会在栈上开辟空间
堆:使用new关键字创建的对象,都在这开辟空间
方法区:存储class文件
寄存器与本地方法栈:我们暂时不需要了解
一个简单的java程序,运行时的内存图
①加载class文件
②main方法为主入口,main方法进制
③调用show方法,show方法进栈
④show调用完出栈
④为变量a在栈上开辟空间
⑤输出a
数组何时用动态初始化、何时用静态
数组是在哪里开辟空间的
数组名==数组名比较的是什么
--结束END--
本文标题: [正式学习java②]——数组的基本使用,java内存图与内存分配
本文链接: https://www.lsjlt.com/news/433450.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-04-01
2024-04-03
2024-04-03
2024-01-21
2024-01-21
2024-01-21
2024-01-21
2023-12-23
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0