第3章 数组

定义

  • 数组(Array),是多个相同类型数据一定顺序排列的集合,并使用一个名字命名,并通过编号的方式对这些数据进行统一管理。
  • 常见概念
    • 数组名
    • 下标(或索引)
    • 元素
    • 数组的长度

概述

  • 数组本身是引用数据类型,而数组中的元素可以是任何数据类型,包括基本数据类型和引用数据类型。
  • 创建数组对象会在内存中开辟一整块连续的空间,而数组名中引用的是这块连续空间的首地址
  • 数组的长度一旦确定,就不能修改
  • 可以直接通过==下标(或索引)==的方式调用指定位置的元素,速度很快。

分类

按照维度:可以分为一维数组、多维数组。

一维数组

一维数组声明

Java中声明数组时不能指定其长度,如 int a[5]; 是非法的。

// 两种格式
type var[];
type[] var2;

//举例
int a[];
int[] a1;
double b[];
//引用类型变量数组
String[] c; 
一维数组初始化
  • 动态初始化
    • 数组声明且为数组元素分配空间与赋值的操作分开进行
// 声明
int[] arr = new int[3];
// 初始化
arr[0] = 3;
arr[1] = 9;
arr[2] = 8;

// 声明
String names[];
// 初始化
names = new String[3];
names[0] = “钱学森”;
names[1] = “邓稼先”;
names[2] = “袁隆平”;
  • 静态初始化
    • 在定义数组的同时就为数组元素分配空间并赋值。
int arr[] = new int[]{3,9,8};
int[] brr = {3,9,8};

String names[] = {
	"李四光","茅以升","华罗庚"
}
一维数组使用
  • 数组元素的引用

    • 定义数组并new为其分配空间后,才可以引用数组中的元素。
    • 引用方式:数组名[数组元素下标]
    • 数组元素下标可以是整型常量或整型表达式。
      • 如a[3] , b[i] , c[6*i];
    • 数组元素下标从0开始;长度为n的数组合法下标取值范围: 0 —>n-1
      • 如int a[]=new int[3];
      • 可引用的数组元素为 a[0]、a[1]、a[2]
    • 每个数组都有一个属性length指明它的长度。
      • 如:a.length 指明数组a的长度(元素个数)
    • 数组一旦初始化,其长度是不可变的。
  • 默认初始化值

    • 数组是引用类型,它的元素相当于类的成员变量,因此数组一经分配空间,其中的每个元素也被按照成员变量同样的方式被隐式初始化
public class Test {
    public static void main(String argv[]){
        int a[]= new int[5];
        System.out.println(a[3]); //a[3]的默认值为0 
        
        char a[] = new char[3];
		System.out.println("---" + a[0] + "***"); //--- ***
		System.out.print(0 == a[0]); //true
    } 
}
  • 内存解析

JVM内存结构图如下请添加图片描述

int arr[] = new int[]{1,2,3};
int arr2[] = arr;
  1. 首先在栈内存中创建arr局部变量
  2. 在堆内存中开辟一个连续空间,共3块,首地址假设为0x34ab。
  3. 栈内存中的arr存值设为0x34ab,即指向堆内存中开辟空间的首地址,此时默认值均为0。
  4. 分别给堆内存中arr[0],arr[1],arr[2] 赋值为1,2,3。
  5. 将数组arr的值即堆内存数据的首地址0x34ab赋值给arr2,两个堆内存中的变量均指向堆内存中同一个地址,这种方式不是数组的复制。
    请添加图片描述

多维数组

对于二维数组,可以看成是一维数组array1作为另一个一维数组array2的元素而存在。从数组底层的运行机制来看,其实没有多维数组。

多维数组声明
// 两种格式
type var[][];
type[][] var2;

//举例
int a[][];
int[][] a1;
double b[][];
//引用类型变量数组
String[][] c; 
多维数组初始化

当使用new 来创建多维数组时,不必指定每一维的大小,但要指定最左边的维的大小

  • 动态初始化
/*
 * 格式一
 * 定义了名称为arr的二维数组,二维数组中有3个一维数组
 * 每个一维数组中有2个元素
 * 一维数组的名称分别为arr[0], arr[1], arr[2]
 */
int[][] arr = new int[3][2];
arr[0][1] = 78;

/* 
 * 格式二
 * 定义了名称为arr的二维数组,二维数组中有3个一维数组
 * 每个一维数组都是默认初始化值null (注意:区别于格式1)
 */
int[][] arr = new int[3][];
arr[0] = new int[3]; 
arr[1] = new int[1];
arr[2] = new int[2];

//非法
int[][]arr = new int[][3];
  • 静态初始化
/*
 * 定义一个名称为arr的二维数组,二维数组中有三个一维数组
 * 每个一维数组中具体元素也都已初始化
 * 
 * 第一个一维数组 arr[0] = {3,8,2};
 * 第二个一维数组 arr[1] = {2,7};
 * 第三个一维数组 arr[2] = {9,0,1,6};
 * 
 * 第三个一维数组的长度表示方式:arr[2].length;
 */
int[][] arr = new int{
    {3,8,2},
    {2,7},
    {9,0,1,6}
};

int arr1[][] = {
    {3,8,2},
    {2,7},
    {9,0,1,6}
};
  • 注意
    • 特殊写法情况:int[] x,y[]; x是一维数组,y是二维数组。
    • Java中多维数组不必都是规则矩阵形式
多维数组使用

多维数组的数组名如arr,直接输出是第一个维度数组的首地址,arr.length是第一个维度数组的长度。

int[][] arr = new int [4][];
System.out.println(arr);	// [[I@15db9742
arr[0] = new int[3];
System.out.println(arr[0]);	// [I@6d06d69c
System.out.println(arr[1]);	// null
System.out.println(arr[0][0]);	// 0

System.out.println(arr.length);	// 4
System.out.println(arr[0].length);	// 3
image-20200322155443820

数组例题

Arrays工具类

定义在java.util包下,提供了很多操作数组的方法。

方法描述
boolean equals(int[] a,int[] b)判断两个数组是否相等。
String toString(int[] a)输出数组信息。
void fill(int[] a,int val)将指定值填充到数组之中
void sort(int[] a)对数组进行排序。
int binarySearch(int[] a,int key)对排序后的数组进行二分法检索指定的值。
import java.util.Arrays;
/*
 * java.util.Arrays:操作数组的工具类,里面定义了很多操作数组的方法
 */
public class ArraysTest {
	public static void main(String[] args) {
		
		//1.boolean equals(int[] a,int[] b):判断两个数组是否相等。
		int[] arr1 = new int[]{1,2,3,4};
		int[] arr2 = new int[]{1,3,2,4};
		boolean isEquals = Arrays.equals(arr1, arr2);
		System.out.println(isEquals);
		
		//2.String toString(int[] a):输出数组信息。
		System.out.println(Arrays.toString(arr1));
		
			
		//3.void fill(int[] a,int val):将指定值填充到数组之中。
		Arrays.fill(arr1,10);
		System.out.println(Arrays.toString(arr1));

		//4.void sort(int[] a):对数组进行排序。
		Arrays.sort(arr2);
		System.out.println(Arrays.toString(arr2));
		
		//5.int binarySearch(int[] a,int key)
		int[] arr3 = new int[]{-98,-34,2,34,54,66,79,105,210,333};
		int index = Arrays.binarySearch(arr3, 210);
		if(index >= 0){
			System.out.println(index);
		}else{
			System.out.println("未找到");
		}
	}
}

数组使用常见异常

数组脚标越界异常(ArrayIndexOutOfBoundsException)

访问到了数组中的不存在的脚标时发生。

int[] arr = new int[2];
System.out.println(arr[2]);
System.out.println(arr[-1]);

空指针异常(NullPointerException)

arr引用没有指向实体,却在操作实体中的元素时。

int[] arr = null;
System.out.println(arr[0]);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值