如何在Java中做一个二维数组的深层拷贝?

我刚刚在我的二.clone()数组上使用.clone() ,认为这是一个深层复制。

我怎样才能执行我的boolean[][]数组的深层副本?

我是否应该循环执行一系列System.arraycopy

是的,你应该迭代2D布尔数组,以深入复制它。 如果您在Java 6上,也请看java.util.Arrays#copyOf方法。

我会build议Java 6的下一个代码:

 public static boolean[][] deepCopy(boolean[][] original) { if (original == null) { return null; } final boolean[][] result = new boolean[original.length][]; for (int i = 0; i < original.length; i++) { result[i] = Arrays.copyOf(original[i], original[i].length); // For Java versions prior to Java 6 use the next: // System.arraycopy(original[i], 0, result[i], 0, original[i].length); } return result; } 

我设法想出一个recursion数组深层复制。 即使对于具有不同尺寸长度的multidimensional array,它似乎也工作得很好

 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> 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); } 

编辑:更新了与​​原始数组一起工作的代码。

我是Arrays工具的粉丝。 它有一个copyOf方法,可以为你做一个一维数组的深层副本,所以你需要这样的东西:

 //say you have boolean[][] foo; boolean[][] nv = new boolean[foo.length][foo[0].length]; for (int i = 0; i < nv.length; i++) nv[i] = Arrays.copyOf(foo[i], foo[i].length); 

是的,这是做到这一点的唯一方法。 java.util.Arrays commons-lang都不提供数组的深度拷贝。

在Java 8中,这可以通过使用lambdaexpression式来实现:

 <T> T[][] deepCopy(T[][] matrix) { return java.util.Arrays.stream(matrix).map(el -> el.clone()).toArray($ -> matrix.clone()); }