数组元素访问
格式:数组名[索引];
索引:也叫做下标,角标。索引从0开始,逐个 +1 增长,连续不间断,到数组长度 -1 结束
把数据存储到数组中,格式:数组名[索引] = 具体数据/变量
一旦覆盖后,原来的数据就不存在了
例:arr[0] = 100; System.out.println(arr[0]); // 100
数组遍历
数组遍历:遍历指的是数组取出的过程,不能局限理解为遍历就是打印
在Java中,关于数组的长度属性:length 调用方法:数组名.length
自动快速生成数组的遍历方式(idea)提供:数组名.fori 会自动生成for (int i = 0; i < arr.length; i++) {}
一个循环尽量只做一件事
数组常见问题
当访问量数组中不存在的索引,就会引发索引越界异常
例:int[] arr = {1,2,3,4,5}; System.out.println(arr[5]); // 此时就会出现索引异常
数组常见操作:求最值、求和、交换数据、打乱数据
java内存分配
栈(stack):方法运行时使用的内存,比如main方法运行,进入方法栈中执行 开始执行时进入栈,代码执行完出栈 通常放局部变量
堆(heap):存储对象或数组,new来创建的,都存储到堆内存 new出来的东西会在这块内存开辟空间并产生地址值
方法区:存储可以运行的class文件 存放常量池、静态域
本地方法栈:JVM在使用操作系统功能时使用,和开发无关
寄存器:给CPU使用,与开发无关
注意:从JDK8开始,取消方法区,新增元空间。把原来方法区的功能进行拆分,有的放到了堆,有的放到了元空间
总结:只要是new出来的一定在堆里面开辟的一个小空间,如果new了多次,那么在堆里面有多个小空间,每个小空间都有各自的数据
两个数组指向同一个空间的内存图:当两个数组指向同一个小空间时,其中一个数组对小空间中的值发生了改变,那么其他数组再访问时也是改变后的结果
二维数组
需要把数据分组管理,用到二维数组
二维数组初始化:静态初始化、动态初始化
静态初始化格式:数据类型[][] arr = new 数据类型[][]{
{元素1,元素2},{元素1,元素2}};
简化格式:数据类型[][] arr = {
{元素1,元素2},{元素1,元素2}};
建议把每个一维数组单独写一行,便于观察
例:
int[][] arr = {
{1,2,3},
{4,5,6}
};
获取元素:arr[0][0] arr[0]表示二维数组中第一个数组,arr[0][0]表示第一个数组的第一个元素
二维数组遍历:
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
System.out.println(arr[i][j]);
}
}
动态初始化:数据类型[][] arr = new 数据类型[m] [n];
m表示二维数组中存多少一维数组,n表示一维数组可以存多少元素