带你入门Java的数组

这篇文章主要给大家介绍了关于Java中数组的定义和使用的相关资料,,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

目录

数组的定义

数组的声明和创建

1.动态初始化

2.静态初始化

3.数组的认初始化

数组的四个基本特点

数组边界

数组的使用

Arrays类

总结

数组的定义

数组是相同类型数据的有序集合

数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成

其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们。

数组的声明和创建

首先必须声明数组变量,才能在程序中使用数组。下面是声明数组变量的语法:

dataType[] arrayRefVar;//首选方法 或 dataType arrayRefVar[];

Java语言使用new操作符来创建数组,语法如下:

dataType[] arrayRefVar = new dataType[arraySize];

数组的元素是通过索引访问的,数组索引从0开始。

获取数组长度:arrays.length

数组的创建的初始化方式:

1.动态初始化

int[] a = new int[5]; int[0] = 1; int[1] = 2;int[2] = 3;int[3] = 4;int[4] = 5;

2.静态初始化

int[] b = new int[]{1,2,3,4,5}; int[] c = {1,2,3,4,5};

3.数组的认初始化

数组引用类型,它的元素相当于类的实例变量,因此数组一经分配空间,其中的每个元素也被按照实例变量同样的方式被隐式初始化。

数组的四个基本特点

其长度是确定的。数组一旦被创建,它的大小就是不可以改变的。

其元素必须是相同类型,不允许出现混合类型

数组中的元素可以是任何数据类型,包括基本类型和引用类型

数组变量属引用类型,数组也可以看成是对象,数组中每个元素相当于该对象的成员变量。数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身就在堆中

数组边界

下标合法区间:[0,length-1],如果越界就会报错;

Arrayindexoutofboundsexception:数组下标越界异常

小结

数组是相同数据类型(数据类型可以为任意类型)的有序集合

数组也是对象。数组元素相当于对象的成员变量

数组长度的是确定的,不可变的。如果越界就会报错:Arrayindexoutofboundsexception

数组的使用

package com.cnblogs; /* * 本类用于测试数组01 遍历数组 */ public class TestArr1 { public static void main(String[] args) { int[] arr = {1,2,3,4,5,6,7,8,9}; //遍历数组 for(int i = 0; i

多维数组

多维数组可以看成是数组的数组,比如二维数组就是一个特殊的数组,其每一个元素都是一个一维数组。

二维数组

int[][] a = new int[2][5]//两行,五列

package com.cnblogs; /* * 本类用于测试数组01 遍历二维数组 */ public class TestArr2 { public static void main(String[] args) { int[][] arr = {{1,2},{2,3},{3,4},{4,5}}; for(int i = 0 ; i

Arrays类

数组工具类java.util.Arrays

由于数组对象本身并没有什么方法可以供我们调用,但API中提供了一个工具类Arrays供我们使用,从而可以对数据对象进行一些基本操作

查看JDK帮助文档

Arrays类中的方法都是static修饰的静态方法,在使用的时候可以直接使用类名进行调用,而“不用”使用对象来调用(是“不用”而不是“不能”)

具有以下常用功能

给数组赋值:通过fill方法

对数组排序:通过sort方法,按升序

比较数组:通过equals方法比较数组中元素是否相等

查找数组元素:通过binarySearch方法能对排序好的数组进行二分查找法操作

把数组赋值成一个指定长度的新数组:通过 Arrays.copyOf(数组,新的长度)方法

新数组的长度 大于 原数组, 相当于复制,并增加位置

新数组的长度 小于 原数组, 相当于截取一部分数据

package com.cnblogs; /* * 本类用于测试数组03 Arrays类 */ //导入Arrays类 import java.util.Arrays; public class TestArr3 { public static void main(String[] args) { int[] arr = {1,2,3,4,5,6,28,15,13,9}; System.out.println(arr);//[I@3fb6a447 这里打印的是内存地址 //打印数组元素 System.out.println(Arrays.toString(arr));//[1, 2, 3, 4, 5, 6, 28, 15, 13, 9] //数组进行排序,升序 Arrays.sort(arr); System.out.println(Arrays.toString(arr));//[1, 2, 3, 4, 5, 6, 9, 13, 15, 28] //数组的填充 Arrays.fill(arr,6); System.out.println(Arrays.toString(arr));//[6, 6, 6, 6, 6, 6, 6, 6, 6, 6] Arrays.fill(arr,2,4,8);//填充2-4 包括2 不包括4 System.out.println(Arrays.toString(arr));//[6, 6, 8, 8, 6, 6, 6, 6, 6, 6] } }

总结

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...