java 数组深度拷贝_如何在Java中对2d数组进行深度复制?

我已经想出了一个递归数组深度复制。即使对于具有不同尺寸长度的多维数组,它似乎也能很好地工作。private static final int[][][] INT_3D_ARRAY = {

{

{1}

},

{

{2, 3},

{4, 5}

},

{

{6, 7, 8},

{9, 10, 11},

{12, 13, 14}

}};

这是实用方法。@SuppressWarnings("unchecked")public static  T[] deepCopyOf(T[] array) {

if (0 >= array.length) return array;

return (T[]) deepCopyOf(

array,

Array.newInstance(array[0].getClass(), array.length),

0);}private static Object deepCopyOf(Object array, Object copiedArray, int index) {

if (index >= Array.getLength(array)) return copiedArray;

Object element = Array.get(array, index);

if (element.getClass().isArray()) {

Array.set(copiedArray, index, deepCopyOf(

element,

Array.newInstance(

element.getClass().getComponentType(),

Array.getLength(element)),

0));

} else {

Array.set(copiedArray, index, element);

}

return deepCopyOf(array, copiedArray, ++index);}

编辑:更新代码以处理基元数组。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值