北京

点击搜索

发布

拉勾教育Java技术开发之数组知识梳理

区域:
北京 > 海淀 > 中关村
类别:
软件工程师培训
地址:
创业大街
Java是一门面向对象编程语言,具有简单易用、功能强大的特征。数组是同类型数据的有序集合,在Java中是引用数据类型,引用数据类型值都存储在堆中。有很多新手初学Java数组觉得难度大,拉勾IT课小编为大家分析数组知识。

数组的定义及初始化
1、定义一个数组的格式为:数据类型[] 数组名称;数据类型代表数组中保存的数据全都是统一的哪种类型。通过数组名称可以使用其中的多个数据。
2、数组一定要初始化之后才可以使用。初始化是指:为数组在内存当中开辟内存空间,用来保存数据,并且设置默认值。没有初始化的数组无法使用。数组的初始化方式分成两种:
1)动态初始化,指定长度。格式为:
数据类型[] 数组名称 = new 数据类型[长度];
数据类型[] 数组名称;
数组 = new 数据类型[长度];
数组元素的默认值规则为:整数默认为0,浮点数默认为0.0,字符默认为’\u0000’,布尔值默认为false,字符串等引用类型默认为null。

2) 静态初始化,指定内容。除了用new关键字来产生数组以外,还可以直接在定义数组的同时就为数组元素分配空间并赋值。
int[] a = { 1, 2, 3};// 静态初始化基本类型数组
Man[] mans = { newMan(1, 1), newMan(2, 2) };// 静态初始化引用类型数组

访问数组元素
直接打印数组的名称,得到的是“内存地址值”(的哈希值)。要想访问数组中的元素,需要使用格式:数组名称[索引编号]
其中索引编号是数组中元素的int型数字编号,从0开始,一直到数组的长度-1为止。

获取数组长度
无论是动态还是静态初始化,数组一定是具有长度的。获取长度的格式:数组名称.length
这将得到一个int数字代表长度,注意,数组在内存当中一旦被创建,那么长度不可改变。

数组索引越界异常
如果访问的数组元素索引并不存在,那么将会发生异常:java.lang.ArrayIndexOutOfBoundsException。
注意,数组元素索引编号从0开始,一直到“数组长度-1”为止。

数组遍历
public static void main(String[] args) {
int[] arr = new int[3]
;for (int i = 0; i < arr.length; i++) {arr = i + 1;
}
System.out.println(Arrays.toString(arr)); // 输出 [1, 2, 3]
}
如果不需要使用数组小标的化可以使用简化语法:for each,格式为:
for (type item : arrName) {... // 操作}
如:
public static void main(String[] args) {
String[] arr = new String[]{
"hello", "world", "!!"
};for (String v : arr) {
System.out.println(v); // 循环输出arr中的字符串
}
}

数组复制
1) System.arraycopy() 系统提供的方法:
/*** @param src 原数组* @param srcPos 拷贝原数组起始位置* @param dest 目标数组* @param destPos 目标数组起始位置* @param length 拷贝数组元素个数*/public static void native arraycopy(Object src, int srcPos, Object dest, int destPos, int length);
clone对象克隆:
int[] src = {1, 2, 3};int[] dest = src.clone();
3) A***pyOf、A***pyOfRange 方法
int[] src = {1, 2, 3};
int[] dest1 = A***pyOf(src, 3);
int[] dest2 = A***pyOfRange(src, 1, 3);
System.out.println(Arrays.toString(dest1)); // 输出:[1, 2, 3]
System.out.println(Arrays.toString(dest2)); // 输出:[2, 3]
4) for 循环,挨个元素复制
int[] src = new int[]{1, 2, 3};
int[] dest = new int[3];
for (int i = 0;
i < src.length; i++) {
dest = src;
}
System.out.println(Arrays.toString(dest)); // 输出:[1, 2, 3]

数组排序
static void sort(int[] a) // 对整型数组比较后按升序排序
static void sort(int[] a, int fromIndex, int toIndex) // 对整型数组比较指定范围数据按升序排序
public static<T> void sort(T[] a,Comparator c) // 根据指定比较器产生的顺序对指定对象数组进行排序
public static<T> void sort(T[] a,int fromIndex,int toIndex,Comparator c) // 根据指定比较器产生的顺序对指定对象数组的指定范围进行排序

数组查找/搜索
Arrays.binarySearch(Object[] arr, Object key)
arr:要搜索的数组,搜索前必须对数组先进行sort排序
key:要搜索的值返回值:如果key在arr中,则返回搜索值得索引,否则返回-1或-[插入点索引值]
插入点索引值:
1)key不在arr中,且在数组值范围内,从1开始计数,索引值为-[插入点索引值];
2)key不在arr中,且大于数组内元素,索引值为-[arr.length + 1];
3)key不在arr中,且小于数组内元素,索引值为-1。
Arrays.binarySearch(Object[] arr, int fromIndex, int toIndex, Object key)
arr:要搜索的数组,搜索前必须对数组先进行sort排序
fromIndex:查找起始位置
toIndex:查找结束位置
key:要搜索的值
返回值:如果key在arr查找范围中,则返回搜索值得索引,否则返回-1或-[插入点索引值]
插入点索引值:
1)key不在arr中,且在数组值范围内,从1开始计数,索引值为-[插入点索引值];
2)key不在arr中,且大于范围数组内元素,索引值为-[toIndex + 1];
3)key不在arr中,且小于范围数组内元素,索引值为-[fromIndex + 1]。

通过灵活的在线学习,提升java开发技术,同时结合项目实战,增强技术代码经验,增强实战力度

免责声明:此信息系发布者(UID:706396)自行发布,本站是服务平台,仅提供信息存储空间服务,该信息内容的真实性及合法性由该发布者完全负责。

© lieju.com 联系我们