博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java中如何把两个数组合并为一个
阅读量:6844 次
发布时间:2019-06-26

本文共 2007 字,大约阅读时间需要 6 分钟。

转自:http://blog.csdn.net/jaycee110905/article/details/9179227

在中,如何把两个String[]合并为一个?

看起来是一个很简单的问题。但是如何才能把代码写得高效简洁,却还是值得思考的。这里介绍四种方法,请参考选用。

一、apache-commons

这是最简单的办法。在apache-commons中,有一个ArrayUtils.addAll(Object[], Object[])方法,可以让我们一行搞定:

String[] both = (String[]) ArrayUtils.addAll(first, second);

其它的都需要自己调用jdk中提供的方法,包装一下。

为了方便,我将定义一个工具方法concat,可以把两个数组合并在一起:

static String[] concat(String[] first, String[] second) {}

为了通用,在可能的情况下,我将使用泛型来定义,这样不仅String[]可以使用,其它类型的数组也可以使用:

static 
T[] concat(T[] first, T[] second) {}

当然如果你的jdk不支持泛型,或者用不上,你可以手动把T换成String

二、System.arraycopy()

[java]   
  1. static String[] concat(String[] a, String[] b) {  
  2.    String[] c= new String[a.length+b.length];  
  3.    System.arraycopy(a, 0, c, 0, a.length);  
  4.    System.arraycopy(b, 0, c, a.length, b.length);  
  5.    return c;  
  6. }  

使用如下:

String[] both = concat(first, second);

三、Arrays.copyOf()

在java6中,有一个方法Arrays.copyOf(),是一个泛型函数。我们可以利用它,写出更通用的合并方法:

[java]   
  1. public static <T> T[] concat(T[] first, T[] second) {  
  2.   T[] result = Arrays.copyOf(first, first.length + second.length);  
  3.   System.arraycopy(second, 0, result, first.length, second.length);  
  4.   return result;  
  5. }           

如果要合并多个,可以这样写:

[java]   
  1. public static <T> T[] concatAll(T[] first, T[]... rest) {  
  2.   int totalLength = first.length;  
  3.   for (T[] array : rest) {  
  4.     totalLength += array.length;  
  5.   }  
  6.   T[] result = Arrays.copyOf(first, totalLength);  
  7.   int offset = first.length;  
  8.   for (T[] array : rest) {  
  9.     System.arraycopy(array, 0, result, offset, array.length);  
  10.     offset += array.length;  
  11.   }  
  12.   return result;  
  13. }  

使用如下:

String[] both = concat(first, second); String[] more = concat(first, second, third, fourth);

四、Array.newInstance

还可以使用Array.newInstance来生成数组:

[java]   
  1. private static <T> T[] concat(T[] a, T[] b) {  
  2.     final int alen = a.length;  
  3.     final int blen = b.length;  
  4.     if (alen == 0) {  
  5.         return b;  
  6.     }  
  7.     if (blen == 0) {  
  8.         return a;  
  9.     }  
  10.     final T[] result = (T[]) java.lang.reflect.Array.  
  11.             newInstance(a.getClass().getComponentType(), alen + blen);  
  12.     System.arraycopy(a, 0, result, 0, alen);  
  13.     System.arraycopy(b, 0, result, alen, blen);  
  14.     return result;  
  15. }  

 

你可能感兴趣的文章
常见物联网近距离无线通信技术解析
查看>>
《嵌入式 Linux C 语言应用程序设计(修订版)》——2.2 嵌入式Linux编辑器vi的使用...
查看>>
黑客发现 Adobe Flash 播放器第二个零日漏洞
查看>>
Docker —— 用于统一开发和部署的轻量级 Linux 容器 【已翻译100%】
查看>>
《初级会计电算化应用教程(金蝶KIS专业版)》——1.3 电算化会计信息系统
查看>>
Android 开发者应该使用 FlatBuffers 替代 JSON ?
查看>>
《拥抱变化——社交网络时代的企业转型之道》一找准组织目标和企业文化
查看>>
《Arduino奇妙之旅:智能车趣味制作天龙八步》一3.2 构建小发明
查看>>
《Cisco安全防火墙服务模块(FWSM)解决方案》——第2章防火墙服务模块概述
查看>>
Go语言项目(kingshard)性能优化实例剖析
查看>>
安全预警:ImageMagick 图象处理软件存在远程代码执行(CVE-2016-3714)
查看>>
Google 为什么要把最重要的秘密开源?
查看>>
《Hadoop大数据分析与挖掘实战》——1.5节餐饮服务中的大数据应用
查看>>
《ANSYS Workbench 14有限元分析自学手册》——2.5 体操作
查看>>
《交互式程序设计 第2版》一第1章 交互设计导论
查看>>
ARM拟将ARM核心置入未来的Fusion APU中
查看>>
3分钟参与阿里云《金融行业云上信任报告》调查问卷,98%的几率拿到代金券
查看>>
《C语言编程魔法书:基于C11标准》——2.9 本章小结
查看>>
《移动数据挖掘》—— 1.4 本书简介
查看>>
菲尔兹奖得主维拉尼:七个点子帮你找到科研灵感
查看>>