文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java 基础--Arrays工具类详解

2024-04-02 19:55

关注

Arrays 是 JDK 提供的操作数组的工具类,Arrays 类提供了动态创建、访问和操作 Java 数组的方法。此类还包含一个允许将数组作为列表来查看的静态工厂。

1、数组转换成字符串


public static String toString(T [] a)

如:


int[] a = {2,8,51,13,46,11,22};
System.out.println(Arrays.toString(a));

2、数组转换成集合

(1)asList


public static <T> List<T> asList(T... a)

例:


List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
        System.out.println(list);

1)该方法适用于对象型数据的数组(String、Integer…),该方法不要使用于基本数据类型的数组(byte,short,int,long,float,double,boolean);
2)该方法将数组与List列表链接起来:当更新其一个时,另一个自动更新;
3)不支持add()、remove()、clear()等方法;
4)用此方法得到的List的长度是不可改变的;
5)如果你的List只是用来遍历,就用Arrays.asList();如果你的List还要添加或删除元素, 就new一个java.util.ArrayList,然后一个一个地添加或删除元素;
6)这个ArrayList不是java.util包下的,而是java.util.Arrays.ArrayList。它是Arrays类自己定义的一个静态内部类,这个内部类没有实现add()、remove()方法,而是直接使用它的父类AbstractList的相应方法。

(2)stream 流操作


public static IntStream stream(int[] array)

例:


int[] a = {2,8,51,13,46,11,22};
IntStream stream = Arrays.stream(a);
System.out.println(Arrays.toString(stream.toArray()));
System.out.println(Arrays.toString(a));

将数组转为流式,对array进行流式处理,可用一切流式处理的方法。

(3)Collections.addAll()

3、对数组进行升序排列


public static void sort(T [] a)

例:


int[] a = {20, 3, 32, 1, 72, 26, 35};
Arrays.sort(a);

4、判断数组是否相等


public static boolean equals(T[] a, T[] a2)

例:


int[] a = {20, 3, 32, 1, 72, 26, 35};
int[] b = {3, 5, 7, 8, 54, 23, 9};
boolean boo = Arrays.equals(a, b);

比较的原则是长度相等,元素相等。

5、所有元素赋特定值


// 用val替换数组指定范围的值
public static void fill(T[] a, int fromIndex, int toIndex, T val)

例:


int[] a = {1, 2, 3, 4};
Arrays.fill(a, 0,2,5);

6、对数组复制


public static char[] copyOf(char[] original, int newLength)

例:


int[] b = {3, 5, 7, 8, 54, 23, 9};
int[] d = Arrays.copyOf(b, b.length);

Arrays 的 copyOf() 方法传回的数组是新的数组对象,改变传回数组中的元素值,不会影响原来的数组。
copyOf() 的第二个自变量指定要建立的新数组长度,如果新数组的长度超过原数组的长度,则保留数组默认值。

7、查询数组下标


public static int binarySearch(byte[] a, byte key)     // 查询元素第一次出现的位置

例:


int[] b = {3, 5, 7, 8, 9, 23, 54};
int i = Arrays.binarySearch(b, 5);

使用二分搜索法来搜索指定的数组,方法返回要搜索元素的索引值。
注:必须在进行此调用之前对数组进行排序(sort 方法)。如果没有对数组进行排序,则结果是不明确的。如果数组包含多个带有指定值的元素,则无法保证找到的是哪一个。
查找效率比一般的从数组中从左到右挨个挨个的查找的平均查找时间要快。

8、返回数组 hashcode 值


public static int hashCode(int a[]);    // 返回数组的hashCode值

例:


int[] a = {1, 2, 3, 4};
System.out.println(Arrays.hashCode(a));
// 结果:955331

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯