数组概述
- 定义:
1.相同类型的有序集合
2.按照一定发先后顺序组合
3.每一个数据称作一个数组元素,每个数组元素可以通过一个下标来 访问
数组声明与创建
基本使用
- 必须先声明数组变量,才能在之后使用
dataType[] arrayRefVar; //首选方法
或
dataType arrayRefVar[]; //效果相同,但不是首选方法
- javay语言使用new操作符来创建数组,语法:
dataType[] arrayRefVar = new dataType[arraySize];
- 数组元素通过索引访问,数组索引从0开始
- 数组长度
arrays.length
内存分析
- java内存
1.堆:存放new的对象和数组;可以被所有的线程共享,不会存放别的对象引用
2.栈:存放基本的变量类型(包含基本类型的具体数值);引用对象和变量(会存放这个引用在堆里面的具体地址)
3.方法区:可以被所有的线程共享;包含所有的class和static变量
初始化
-
静态初始化:创建+赋值
int[] a={1,2,3,4,5,6};
//引用类型的初始化
Man[] mans={new Man(),new Man(),new Man()};
-
动态初始化,包含默认初始化
int[] b=new int[10];
b[0]=1;
b[1]=2;
-
默认初始化
数值是引用类型,它的元素相当于类的示例变量,因此数组一经分配空间,其中的每个元素也被按照实例变量相同的方式被隐式初始化。
数组的特点
- 长度确定,完成创建,则大小不可变
- 元素必须为相同类型
- 数组中的元素可以为任何数据类型,包括基本类型和引用类型(类之类的)
- 数组变量属于引用类型,数组可以看成对象,数组中的每个元素相当于该对想的成员变量。
- 数组是对象,Java中对象是在堆中==>因此数组无论保存原始数据类型还是其他对象类型,数组对象本身是在堆中
数组边界
- 数组的下标合理区间:[0,length-1],若越界会报错
- ArrayIndexOutofBoundsException:数组下标越界异常!
数组使用
- 普通for循环
- for-each循环
- 数组作为入参
- 数组作为返回值
多维数组
- 定义:数组的数组
- 二维数组
int[][] a2={{1,2,3},{2,3,4}};
int[][] b2=new int[2][3];
b2[0][0]=1;
b2[0][1]=2;
b2[1][0]=3;
Arrays类
- java.util.Array:java提供是方法类
- 可查看JDK帮助文档
https://tool.oschina.net/apidocs/apidoc?api=jdk-zh - 实例常用功能:
1.给数组赋值:fill()
2.给数组排序:sort() //升序
3.比较数组:equals() //比较数组中的元素值是否相等
4.查找数组元素:binarySearch() 对排序好的数组进行二分查找
稀疏数组
- 作用:一个数组中大部分元素为0,或者为同一个值的数组是,可以使用稀疏数组来报存。
- 处理方式:
1.记录数组一共有几行几列,和都少个不同值
2.把具有不同值的元素的行、列、值记录在一个小规模数组中 - 举例:左侧为原版,右侧为稀疏数组
学习课程:https://www.bilibili.com/video/BV12J41137hu?p=1