用Java抽象数组的维数

Mat*_*iak 10 java arrays multidimensional-array

在Java中,不同维度的数组具有不同的类型.因此,int[]作为参数的方法不能采取int[][]int[][][].我有很多代码,我创建的方法非常相似,但是对于数组的维度.有没有办法处理任意维度的数组,从而抽象出这个常见的功能?

das*_*ght 2

如果您愿意放弃类型安全,您可以通过一点递归(这并不奇怪,对吧?)和反射来做到这一点。

这个想法是以一种向下递归的方式编写方法,直到数组只有一维。一旦你达到了单一维度的水平,就开始工作;否则,递归地调用自己,并在必要时汇总先前级别的发现。

这是一个快速演示:

import java.util.*;
import java.lang.*;
import java.lang.reflect.Array;

class Main {
    public static int sumArray(Object array) {
            Class type = array.getClass();
            if (!type.isArray()) {
                    throw new IllegalArgumentException("array");
            }
            Class ct = type.getComponentType();
            int res = 0;
            int len = Array.getLength(array);
            if (ct.isArray()) {
                    for (int i = 0 ; i != len ; i++) {
                            res += sumArray(Array.get(array, i));
                    }
            } else {
                    for (int i = 0 ; i != len ; i++) {
                            res += Array.getInt(array, i);
                    }
            }
            return res;
    }
    public static void main (String[] args) throws java.lang.Exception
    {
            int[] a = new int[] {1,2,3,4,5,6,7,8,9,10};
            int aa[][] = new int[][] {{1,2},{3,4},{5,6}};
            int aaa[][][] = new int[][][]{{{1,2},{3,4},{5,6}},{{7,8},{9,10},{11,12}}};
            System.out.println(sumArray(a));
            System.out.println(sumArray(aa));
            System.out.println(sumArray(aaa));
    }
}
Run Code Online (Sandbox Code Playgroud)