java 数组排序-java json数组排序
Java是一门面向对象编程语言,具有简单易用、功能强大的特征。数组是同类型数据的有序集合,在Java中是引用数据类型,引用数据类型值都存储在堆中。有很多新手初学Java数组觉得难度大,接下来千锋武汉Java培训小编就给大家简单梳理一下数组相关的知识点。
一、数组的定义及初始化
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) };// 静态初始化引用类型数组
二、访问数组元素
直接打印数组的名称java 数组排序,得到的是“内存地址值”(的哈希值)。要想访问数组中的元素,需要使用格式:数组名称[索引编号]
其中索引编号是数组中元素的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] = 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);
2) clone对象克隆:
int[] src = {1, 2, 3};int[] dest = src.clone();
3) Arrays.copyOf、Arrays.copyOfRange 方法
int[] src = {1, 2, 3};
int[] dest1 = Arrays.copyOf(src, 3);
int[] dest2 = Arrays.copyOfRange(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[i] = src[i];
}
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 void sort(T[] a,Comparator c) // 根据指定比较器产生的顺序对指定对象数组进行排序
public static void sort(T[] a,int fromIndex,int toIndexjava 数组排序,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培训小编整理的数组的相关知识点。Java基础知识点繁多,你需要认真掌握。如果你想快速系统的入门Java开发、掌握企业所需的核心技术点,可以来千锋武汉Java培训班。专业大牛讲师全程面授,以就业为导向、以实战项目驱动教学过程和内容,实力打造上岗即用的精英人才!并且,千锋推出长达两周的免费试听期,让你亲身教学效果,评价讲师的教学水平,了解学员的学习情况和就业情况!可以关注“武汉千锋”微信公众号,后台索取试听资格,亲身实地感受教学品质!