当我们要存多个数据的时候,比如收录一个班的人的成绩,我们能不断创建很多个变量来录吗,答案是可以但如果数据超多呢,创建多个变量这种方式也太麻烦了,那么这时候我们就要用到数组
数组:可以看成是相同类型元素的一个集合。在内存中是一段连续的空间
如何定义:
T[] 数组名 = new T[N];
T:表示数组中存放元素的类型
T[]:表示数组的类型
N:表示数组的长度
比如:
int[] array1 = new int[10]; // 创建一个可以容纳10个int类型元素的数组 double[] array2 = new double[5]; // 创建一个可以容纳5个double类型元素的数组 String[] array3 = new double[3]; // 创建一个可以容纳3个字符串元素的数组
数组的初始化又分为静态初始化和动态初始化
动态初始化:在创建数组时,直接指定数组中元素的个数
语法格式:
int[] array = new int[10];
静态初始化:在创建数组时不直接指定数据元素个数,而直接将具体的数据内容进行指定
语法格式:
T[] 数组名称 = {data1, data2, data3, ..., datan};
int[] array1 = new int[]{0,1,2,3,4,5,6,7,8,9};
double[] array2 = new double[]{1.0, 2.0, 3.0, 4.0, 5.0};
String[] array3 = new String[]{"hell", "Java", "!!!"};
注意事项
1.静态初始化虽然没有指定数组的长度,编译器在编译时会根据{}中元素个数来确定数组的长度。
2.静态初始化时, {}中数据类型必须与[]前数据类型一致。
3.静态初始化可以简写,省去后面的new T[]。
静态初始化和动态初始化步骤还可以分为两步,但是格式不能省略
nt[] array1;
array1 = new int[10];
int[] array2;
array2 = new int[]{10, 20, 30};
// 注意省略格式不可以拆分, 否则编译失败
// int[] array3;
// array3 = {1, 2, 3};
数组在内存中是一段连续的空间,空间的编号都是从0开始的,依次递增,该编号称为数组的下标,数组可以通过下标访问其任意位置的元素
int[]array = new int[]{10, 20, 30, 40, 50};
System.out.println(array[0]);
System.out.println(array[1]);
System.out.println(array[2]);
System.out.println(array[3]);
System.out.println(array[4]);
// 也可以通过[]对数组中的元素进行修改
array[0] = 100;
System.out.println(array[0]);
注意事项:
public class Text1 {
public static void main(String[] args) {
int[] arr={1,2,3,4,5};
System.out.println(arr[0]);
System.out.println(arr[1]);
System.out.println(arr[2]);
System.out.println(arr[3]);
System.out.println(arr[4]);
}
}
public class Text1 {
public static void main(String[] args) {
int[] arr={1,2,3,4,5};
for(int i=0;i<arr.length;i++){
System.out.print(arr[i]+" ");
}
}
}
import java.util.Arrays;
public class Text1 {
public static void main(String[] args) {
int[] arr={1,2,3,4,5};
System.out.println(Arrays.toString(arr));
}
}
注:括号的左边写右边的数组存储数据类型,右边写数组名,相当于将数组的元素遍历赋值给右边的x,然后打印出来
public class Text1 {
public static void main(String[] args) {
int[] arr={1,2,3,4,5};
for (int x:arr){
System.out.print(x+" ");
}
}
}
如果对内存中存储的数据不加区分的随意存储,那对内存管理起来将会非常麻烦。
比如这张图片左右对比
因此JVM也对所使用的内存按照功能的不同进行了划分:
现在我们只简单关心堆 和 虚拟机栈这两块空间,后序JVM中还会更详细介绍。
区别:
public static void func() {
int a = 10;
int b = 20;
int[] arr = new int[]{1,2,3};
}
在上述代码中,a、b、arr,都是函数内部的变量,因此其空间都在main方法对应的栈帧中分配。a、b是内置类型的变量,因此其空间中保存的就是给该变量初始化的值。array是数组类型的引用变量,其内部保存的内容可以简单理解成是数组在堆空间中的首地址。
从上图可以看到,引用变量并不直接存储对象本身,可以简单理解成存储的是对象在堆中空间的起始地址。通过该地址,引用变量便可以去操作对象。有点类似C语言中的指针,但是Java中引用要比指针的操作更简单。
null 在 Java 中表示 “空引用” , 也就是一个不指向对象的引用.
int[] arr = null;System.out.println(arr[0]);
null 的作用类似于 C 语言中的 NULL (空指针), 都是表示一个无效的内存位置. 因此不能对这个内存进行任何读写操作. 一旦尝试读写, 就会抛出 NullPointerException.
public class Text1 {
public static void main(String[] args) {
int[] arr={1,2,3,4,5};
}
}
import java.util.Arrays;
public class Text1 {
public static void main(String[] args) {
int[] arr = {5, 6, 4, 2};
sort(arr);
System.out.println(Arrays.toString(arr));
}
static void sort(int[] arr) {
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr.length - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
}
所谓的 “引用” 本质上只是存了一个地址. Java 将数组设定成引用类型, 这样的话后续进行数组参数传参, 其实只是将数组的地址传入到函数形参中. 这样可以避免对整个数组的拷贝(数组可能比较长, 那么拷贝开销就会很大).
import java.util.Arrays;
public class Text1 {
public static void main(String[] args) {
int[] arr = {5, 6, 4, 2};
int[] arr2=sort(arr);
System.out.println(Arrays.toString(arr2));
}
static int[] sort(int[] arr1) {
int[] arr=arr1;
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr.length - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
return arr;
}
}
作为函数返回值时,在sort函数内我们先创建一个arr指向arr1的引用然后对arr进行操作,返回arr用一个数组来接收
更多数组相关内容请听下回讲解,看到这里了,不妨给博主给个三连,要是想持续收听,也可以关注博主, 让我们一起变得更强吧,大家加油!!!!