文章目录
考点
- 1 理解容器的概念
- 2 掌握数组的第一种定义方式
- 3 掌握数组的第二种定义方式
- 4 掌握数组的第三种定义方式
- 5 使用索引访问数组的元素
- 6 了解数组的内存图解
- 7 了解空指针和越界异常
- 8 掌握数组的遍历
- 9 掌握数组最大值的获取
- 10 了解数组反转的原理
- 11 了解数组作为方法参数传递
- 12 了解数组作为方法的返回值
一、数组的定义
动态初始化:数据类型[] 数组名称 = new 数据类型[数组长度]; int[] arr = new int[3];
静态初始化标准格式:数据类型[] 数组名 = new 数据类型[]{元素1,元素2,元素3…}; int[] arr = new int[]{1,2,3,4,5};
静态初始化省略格式:数据类型[] 数组名 = {元素1,元素2,元素3…}; int[] arr = {1,2,3,4,5};
直接打印数组名称,得到的是数组对应的:内存地址哈希值。
二、数组原理内存图
2.1 内存概述
内存是计算机中的重要原件,临时存储区域,作用是运行程序。我们编写的程序是存放在硬盘中的,在硬盘中的程 序是不会运行的,必须放进内存中才能运行,运行完毕后会清空内存。
Java虚拟机要运行程序,必须要对内存进行空间的分配和管理。
2.2 Java虚拟机的内存划分
为了提高运算效率,就对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式。
- JVM的内存划分
区域名称 | 作用 |
---|---|
方法栈 | 方法运行时使用的内存,比如main方法运行,进入方法栈中执行 |
堆内存 | 存储对象或者数组,new来创建的,都存储在堆内存 |
方法区 | 存储可以运行的class文件 |
本地方法栈 | JVM在使用操作系统功能的时候使用,和我们开发无关 |
寄存器 | 给CPU使用,和我们开发无关 |
2.2 数组在内存中的存储
2.2.1 一个数组内存图
2.2.2 两个数组内存图
三、数组的常见操作
3.1 数组越界异常
如果访问数组元素的时候,索引编号并不存在,那么将会发生
数组索引越界异常ArrayIndexOutOfBoundsException
3.2 数组空指针异常
所有的引用类型变量,都可以赋值为一个null值。但是代表其中什么都没有。
数组必须进行new初始化才能使用其中的元素。
如果只是赋值了一个null,没有进行new创建,那么将会发生空指针异常 NullPointerException
原因:忘了new
解决:补上new
3.3 数组反转
四、数组作为方法参数和返回值
任何数据类型都能作为方法的参数类型,或者返回值类型。
数组作为方法的参数,传递进去的其实是数组的地址值。
数组作为方法的返回值,返回的其实也是数组的地址值。
4.1 方法的参数类型区别
方法的参数为基本类型时,传递的是数据值. 方法的参数为引用类型时,传递的是地址值