Java 泛型和数字

2022-09-02 20:51:11

为了看看我是否可以清理一些数学代码,主要是矩阵的东西,我正在尝试使用一些Java泛型。我有以下方法:

private <T> T[][] zeroMatrix(int row, int col) {
    T[][] retVal = (T[][])new Object[row][col];
    for(int i = row; i < row; i++) {
        for(int j = col; j < col; j++) {
            retVal[i][j] = 0;
        }
    }
    return retVal;
}

retVal[i][j] = 0是引起我头痛的线。该行的目标是使用 T 表示形式 0 初始化数组。我试图用它做各种各样的事情:(T在类中被定义为T扩展数字)

retVal[i][j] = (T)0;
retVal[i][j] = new T(0);

唯一有效的是

retVal[i][j] = (T)new Object(0);

这不是我想要的。

这可能吗?有没有更简单的方法来表示任何类型的数字(包括潜在的BigDecimal)的NxM矩阵,或者我卡住了?


答案 1
<T extends Number> T[][] zeroMatrix(Class<? extends Number> of, int row, int col) {
    T[][] matrix = (T[][]) java.lang.reflect.Array.newInstance(of, row, col);
    T zero = (T) of.getConstructor(String.class).newInstance("0");
    // not handling exception      

    for (int i = 0; i < row; i++) {
        for (int j = 0; j < col; 
            matrix[i][j] = zero;
        }
    }

    return matrix;
}

用法:

    BigInteger[][] bigIntegerMatrix = zeroMatrix(BigInteger.class, 3, 3);
    Integer[][] integerMatrix = zeroMatrix(Integer.class, 3, 3);
    Float[][] floatMatrix = zeroMatrix(Float.class, 3, 3);
    String[][] error = zeroMatrix(String.class, 3, 3); // <--- compile time error
    System.out.println(Arrays.deepToString(bigIntegerMatrix));
    System.out.println(Arrays.deepToString(integerMatrix));
    System.out.println(Arrays.deepToString(floatMatrix));

编辑

一个通用矩阵:

public static <T> T[][] fillMatrix(Object fill, int row, int col) {
    T[][] matrix = (T[][]) Array.newInstance(fill.getClass(), row, col);

    for (int i = 0; i < row; i++) {
        for (int j = 0; j < col; j++) {
            matrix[i][j] = (T) fill;
        }
    }

    return matrix;
}    

Integer[][] zeroMatrix = fillMatrix(0, 3, 3); // a zero-filled 3x3 matrix
String[][] stringMatrix = fillMatrix("B", 2, 2); // a B-filled 2x2 matrix

答案 2

数组和泛型不能很好地协同工作:

“数组是协变的,这意味着超类型引用的数组是子类型引用数组的超类型。也就是说,是 的超类型,并且可以通过类型的引用变量访问字符串数组。Object[]String[]Object[]

请参阅 Java 泛型常见问题解答


推荐