目录
1、数组的基本概念
2、数组的引用分析
3、数组的静态初始化
4、二维数组
5、数组相关操作方法
6、对象数组
数组指的是一组相关变量的集合。Java中,数组属于引用数据类型,所以必然牵扯到内存的关系。对于数组的定义格式包括:
以上可以看出定义格式 和 实例化对象的思路基本一致,eg:
int data[] = new int[3];
data[0] = 10;
data[1] = 20;
data[2] = 30;
以上操作属于数组的动态初始化,其特点是数组开辟空间后,每个数组元素 的内容为对应数据类型的默认值。
通过数组[索引]方式进行数组的访问,索引的范围:0~长度-1;若超过此范围,程序允许时会出现ArrayIndexOutofBoundsException(数组索引超出绑定异常,数组越界)
【数组输出】:使用for循环即可,关键是用数组名.length获取数组的长度,不再代码举例赘述。
引用数据类型分析基本一致,与对象的流程一样的,唯一的区别就是普通类的对象是保存属性,利用属性名称操作,而数组保存的是内容,利用索引来操作。
【举例】:数组的引用操作
int data[] = new int[3];
data[0] = 10;
data[1] = 20;
data[2] = 30;
int temp[] = data;
temp[0]=100;
for(int i=0;i
以上数组的动态初始化,其特点是,先开辟数组内容空间,再进行内容的赋值,若想数组开辟后直接存在明确内容,可以使用数组的静态初始化:
【举例】:数组的静态初始化
int data[] = new int[] {10,20,30};
【举例】:判断某个数字是否存在于数组中
int data[] = new int[] {10,20,30};
int x =10;
boolean flag = false;
for(int i=0;i
但是以上的做法性能不好,它需要将数组中每一个元素遍历判断,直到找到为止。这里涉及到算法的问题,有个查找算法叫二分查找法,但是使用的前提是数组中的数据必须是有序的,二分查找法原理不再赘述了。
之前使用的数组只有一个索引下标,二维数组有行和列,要想确认一个数据得有行索引 和 列索引。对于二维数组的定义方式:
{数据,,,},{数据,,,},...
};
【举例】:观察二维数组使用
int data[][] = new int[][] {{10,20,30},{11,321,31}};
for(int x=0;x
【举例】:实现二维数组转置
int data[][] = new int[][] {{1,2,3},{4,5,6},{7,8,9}};
for(int x=0;x
以上实际开发中帮助不大,仅训练逻辑思维用。
数组拷贝:System.arraycopy(原始数组,起始位号,目标数组,起始位号,copy个数);
数组排序:Arrays.sort(数组);
具体应用不再赘述了。
对象数组就是某一个数组中保存的都是对象,对象数组的定义格式:
【举例】:动态初始化定义数组
Person per[] =new Person[3];
per[0] =new Person("张三",10);
per[1] =new Person("李四",20);
per[2] =new Person("王五",30);
【举例】:静态初始化定义数组
Person per1 =new Person("张三",10);
Person per2 =new Person("李四",20);
Person per3 =new Person("王五",30);
Person per[] =new Person[]{per1,per2,per3};
或者
Person per[] =new Person[]{
new Person("张三",10),
new Person("李四",20),
new Person("王五",30)};