登录
首页 >  文章 >  java教程

Java数组合并技巧:System.arraycopy轻松拼接

时间:2026-04-14 12:19:35 276浏览 收藏

本文深入解析了Java中使用System.arraycopy高效合并数组的核心技巧与常见陷阱:强调类型兼容性(子类数组可向上拷贝但基本类型与包装类完全不互通)、目标数组长度和起始位置的精准计算(拼接时第二段必须从第一段长度处开始,避免覆盖或越界)、null安全检查的必要性,以及对比Arrays.copyOf的适用场景;同时提醒开发者警惕默认值掩盖数据缺失、Android低版本大数组性能问题等实战细节——掌握这些,才能让数组拼接既高效又健壮。

Java中如何实现两个数组的合并_System.arraycopy拼接技巧

System.arraycopy 合并两个数组前,先确认类型和长度是否匹配

Java 里 System.arraycopy 不做类型检查,也不自动扩容,它只是“抄内存”。如果目标数组不够大,会直接抛 ArrayStoreExceptionIndexOutOfBoundsException;如果源数组和目标数组类型不一致(比如把 String[]Object[] 里拷,反过来就不行),运行时就崩。

  • 必须确保目标数组长度 ≥ 源数组长度 + 起始偏移量
  • 源和目标数组类型要兼容:子类数组可拷入父类数组(String[]Object[]),但反向不行
  • 基本类型数组之间完全不兼容(int[]long[] 不能混用)

拼接两个同类型数组的四参数写法

拼接本质是两次拷贝:先把第一个数组拷进新数组,再把第二个数组从第一个数组长度处开始追加。关键在第三个参数——目标数组的起始位置,容易错写成 0 导致覆盖。

String[] a = {"a", "b"};
String[] b = {"c", "d", "e"};
String[] merged = new String[a.length + b.length];
System.arraycopy(a, 0, merged, 0, a.length);
System.arraycopy(b, 0, merged, a.length, b.length); // 注意这里不是 0
  • System.arraycopy 第 3 个参数是目标数组的起始下标,拼接时得填前一个数组的长度
  • 第 5 个参数是拷贝元素个数,别用 b.length()(那是字符串方法)
  • 如果数组是 null,调用前必须判空,否则直接 NullPointerException

合并时要不要用 Arrays.copyOf?看场景

如果只是临时拼接、且已知其中一个数组是“主数组”,用 Arrays.copyOf 配合一次 System.arraycopy 更简洁;但如果两个数组地位平等、或需要精确控制内存(比如避免多一次数组创建),还是手写两段 System.arraycopy 更直接。

  • Arrays.copyOf(a, a.length + b.length) 底层也是调 System.arraycopy,但多一次分配
  • 泛型集合(如 List)不要强行转数组再拼——new ArrayList(aList) {{ addAll(bList); }} 更安全
  • 大量小数组拼接?考虑 StringBuilder(字符串)或预估总长再分配,避免反复拷贝

原始类型数组拼接容易漏掉的细节

int[]double[] 这类,System.arraycopy 是唯一高效选择,但要注意:它们不能像引用类型那样靠向上转型“绕过”类型检查,而且默认值(00.0)可能掩盖未拷贝的区域。

  • 别依赖“目标数组初始化为 0”来省略拷贝——如果只拷了前半部分,后半部分的 0 是默认值,不是你想要的数据
  • System.arraycopyint[]Integer[]?不行,编译就报错,基本类型和包装类数组完全不互通
  • Android 上低版本(API
实际写的时候,最常卡住的不是语法,而是目标数组长度算错、起始位置填反、或者忘了 null 检查——这三处一错,异常信息看着像底层问题,其实就在那几行里。

好了,本文到此结束,带大家了解了《Java数组合并技巧:System.arraycopy轻松拼接》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>