Java BigInteger mod给出了意想不到的结果

时间:2017-04-14 04:07:55

标签: java biginteger crc

我正在尝试使用Java实现循环冗余检查,我制作了一个快速代码,看它是否按预期工作。

我必须获取大量数据(128个字节)并使用CRC进行检查,因此我认为我应该将二进制值存储在BigInteger中以执行计算。我想过使用字节数组,但我不确定如何在字节数组上执行mod。

为了测试代码,我使用了小值,但是我的剩余值得到了意想不到的结果。

    // Set G value
    BigInteger bigI = new BigInteger("110010", 2);
    String str = bigI.toString(2);
    System.out.println("G = " + str);
    System.out.println(bigI);

    // Set D value
    BigInteger bigI2 = new BigInteger("1011010010", 2);
    String str2 = bigI2.toString(2);
    System.out.println("D1 = " + str2);

    // Append zeroes to D
    String str3 = str2 + "00000";
    bigI2 = new BigInteger(str3, 2);
    str3 = bigI2.toString(2);
    System.out.println("D2 = " + str3);
    System.out.println(bigI2);

    // Get R value
    BigInteger bigI3 = bigI2.mod(bigI);
    String str4 = bigI3.toString(2);
    System.out.println("R = " + str4);

    // Add R to D
    BigInteger bigI4 = bigI3.add(bigI2);
    String str5 = bigI4.toString(2);
    System.out.println("D3 = " + str5);

    // Get final remainder (nonzero == error)
    BigInteger bigI5 = bigI4.mod(bigI);
    String str6 = bigI5.toString(2);
    System.out.println("Remainder = " + str6);

我的输出是:

G = 110010
50
D1 = 1011010010
D2 = 101101001000000
23104
R = 100
D3 = 101101001000100
Remainder = 1000

当我修改前两个值(23104和50)时,我得到4.我在计算器上仔细检查了它,它是相同的(使用小数)。但是,如果你取二进制值(110010和101101001000000)并修改它们,你应该得到1000(二进制),但是0b1000!= 4.

我在YouTube上观看了this video并使用了相同的值,但我得到了不同的结果。

我是否错误地使用BigInteger?

1 个答案:

答案 0 :(得分:0)

CRC的计算是获得将二进制多项式除以另一个二进制多项式的余数(模)。它与整数除法没有任何关系。