如果您愿意放弃类型安全性,则可以稍作递归(这里没有惊喜,对吗?)和反思。
想法是按照递归的方式编写方法,直到数组只有一个维为止。进入单维度级别后,请执行工作;否则,请递归调用自己,并在必要时汇总来自先前级别的发现。
这是一个快速演示:
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)); }}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)