我正在尝试使用以下代码来获得正确的CRC16,
public static int GenCrc16(final byte[] buffer) {
int crc = 0xffff;
for (int j = 0; j < buffer.length ; j++) {
crc = ((crc >>> 8) | (crc << 8) )& 0xffff;
crc ^= (buffer[j] & 0xff);//byte to int, trunc sign
crc ^= ((crc & 0xff) >> 4);
crc ^= (crc << 12) & 0xffff;
crc ^= ((crc & 0xFF) << 5) & 0xffff;
}
crc &= 0xffff;
return crc;
}
如果我传递字符串,
String input = "00000140 0000000 000000002 0000001";
我得到了0x17B5,它是正确的,但我希望将数据作为 作为原始数据
long[] inputLongArray= {0x00000140, 0x00000000, 0x00000002, 0x00000001}
public static byte[] toByte(long[] longArray) {
ByteBuffer bb = ByteBuffer.allocate(longArray.length * Long.BYTES);
bb.asLongBuffer().put(longArray);
return bb.array();
}
我期望根据https://crccalc.com遵循以下条件:0x1F19 00000140 00000000 00000002 00000001并选择十六进制数据类型和CRC-16 / CCITT-FALSE。
public static void main(String[] args) {
long[] intputarray = {0x00000140, 0x0000000, 0x000000002, 0x0000001};
System.out.println(Integer.toHexString(GenCrc16(toByte(intputarray)));
}
我做错了。在此先感谢您的帮助。
答案 0 :(得分:0)
long
的值是8个字节,也就是16个十六进制数字,因此
long[] {0x00000140, 0x00000000, 0x00000002, 0x00000001}
和
一样
"0000000000000140 0000000000000000 0000000000000002 0000000000000001"
并且都具有CRC-16 / CCITT-FALSE值
E47B
字符串
"00000140 0000000 000000002 0000001"
应该真的是
"00000140 00000000 00000002 00000001"
和
一样
int[] {0x00000140, 0x00000000, 0x00000002, 0x00000001}
并且都具有CRC-16 / CCITT-FALSE值
1F19
public static byte[] toByte(final int... intArray) {
ByteBuffer bb = ByteBuffer.allocate(intArray.length * Integer.BYTES);
bb.asIntBuffer().put(intArray);
return bb.array();
}