java基础——数组及其应用
数组
-
数组时相同类型数据的有序集合
-
数组描述的时相同类型的若干数据,按照一个定的先后次序排列组合而成
-
其中,每一个数据成为数组元素,每个数组元素可以通过一个下标来访问他们
数组的声明&创建
-
首先必须声明数组变量,才能在程序中使用数组。 声明数组变量的语法:
dataRype[] arrayRefVar; // 首先的方法(java)
或者
dataType arrayRefVar[];// 效果相同,但不是首先方法
-
java语言使用new操作符来创建数组。
dataType[] arrayRefVar = new dataType[arraySize] ;
-
数组的元素是通过索引访问的,数组索引从0开始。
-
获取数组的元素:array.length
-
public static void main(String[] args) {
// 建立数组的基本步骤:
// 1. 声明一个数组
int[] nums;
// 2. 创建一个数组(开辟空间)
nums = new int[10];
// 3. 给数组中的元素赋值
for (int i = 0; i < nums.length; i++) {
nums[i] = i+1 ;
}
for (int x : nums) {
System.out.println(x);
}
}
内存分析
java内存:1 堆,2 栈,3 方法区
-
堆:可以存放new的对象和数组。(可以被所有的线程共享,不会存放别的对象引用)
-
栈:存放基本变量类型(包含这个基本变量类型的具体数值);引用对象的变量(会存放这个引用在堆里面的具体地址)
-
方法区:可以被所有的线程共享,包含了所有的class和static变量
由于数组的边界时,时确定的,在超出时,会报错:java.lang.ArrayIndexOutOfBoundsException。
数组的初始化
-
静态初始化:
int[] a ={1,2,3};
Man[] mans ={new Man(1,1),new Man(2,2)}
-
动态初始化:
int[] a = new int[2];
a[0]=1;
a[1]=2;
-
数组的初始化:
-
数组时引用类型,它的元素相当于类的实例变量,因此数组一经分配空间,其中的元素同样被按照实例的变量同样的方式被隐形初始化。
-
数组的基本特点
-
数组的长度是确定的。数组一旦被创建,他的大小就不可以改变的。
-
其元素必须是相同类型,不允许出现混合类型。
-
数组中的元素可以是任何数据类型的,包括基本类型和引用类型。
-
数组变量属于引用类型,数组也可以看成对象,数组中的每个元素都相当于该对象的成员变量 数组本身就是对象,java中对象实在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身在堆中的。
数组的边界
-
下标的合法区间:[0,length-1],如果越界就会报错。
-
java.lang.ArrayIndexOutOfBoundsException。
数组小结
-
数组时相同数据类型(任意类型)的有序集合
-
数组也是对象,数组的元素相当于对象的成员变量
-
数组的长度是确定的。越界就会报错。
数组的使用
-
普通的for循环
-
for-each循环(增强型for循环)
-
数组作方法入参
-
数组做返回值
public class ArrayDemo04 {
public static void main(String[] args) {
int[] array = {1,2,3,4,5};
// 增强for循环,适合打印输出
for (int x : array) {
System.out.println(x);
}
System.out.println("===========");
printArray(array);
System.out.println();
System.out.println("$$$$$$$$$$$$");
int[] reverse = arrayReverse(array);
System.out.println("输入的反转数组如下:");
printArray(reverse);
}
//打印数组
public static void printArray (int[] array){
for (int i = 0; i < array.length; i++) {
System.out.print(array[i]+" ");
}
System.out.println();
System.out.println("*****************");
for (int i = 0; i < array.length; i++) {
System.out.print(array[i]+" ");
}
}
//反转数组(返回值为数组)
public static int[] arrayReverse (int[] array){
int[] result= new int[array.length];
for (int i = 0; i < array.length; i++) {
result[i] = array[array.length-1-i];
}
return result;
}
}