数组
声明变量
int[] array; 或 int array[];
使用new操作符来创建数组
int[] array=new int[arraySize];
数组的元素是通过索引访问的,数组索引从0开始。
获取数组长度:array.length
数组初始化
静态初始化:指定每个数组元素的初始值,由系统决定数组的长度
int[] a={1 4 7}; Arr[] arr={new Arr(1,1),new Arr{2,2}};
动态初始化:程序员指定数组的长度
int[] i=new int[2]; a[0]=0;a[1]=9;
数组的特点
长度是确定的;大小不能改变;元素必须是相同类型;数组本身就是对象在堆中;数组变量属于引用类型也可以看成是对象,数组中的每个元素相当于该对象的成员变量。
for-each循环
打印数组a中的每一个元素,没有下标 for(int array : a ){System.out.println(array);}
Array类中的方法都是static修饰的静态方法,可以使用的时候可以直接使用类名进行调用。
冒泡排序
时间复杂度为O(n2)
稀疏数组
处理方式:记录数组一共几行几列,有多少不同的值;把具有不同值的元素和列及值记录在一个小规模的数组中。
内存分析【ArrayIndexOutOfBoundsExcepion异常:数组下标越界异常】
堆:存放new的对象和数组,可以被所有的线程共享,不会存放别的对象引用
栈:存放基本变量类型,引用对象的变量
方法区:可以被所有的线程共享,包含所有的类和static变量