Java создает байт XOR 2 байта
У меня есть 2 байтовых массива, каждый из которых содержит 4 байта (byte1[], byte2 []), и я хочу XOR их создать новый 4-байтовый массив (byte3[]) как бы я это сделал?
(или даже сделать каждый байт за раз, а затем поместить их в новый массив)
4 ответов
вам нужно преобразовать их в целые числа (без потерь, примитивное расширение), сделать XOR, а затем преобразовать полученный int обратно в байт с помощью битовой маски.
// convert to ints and xor
int one = (int)byte1[0];
int two = (int)byte2[0];
int xor = one ^ two;
// convert back to byte
byte b = (byte)(0xff & xor);
пример
String a = "10101010";
String b = "01010101";
String expected = "11111111"; // expected result of a ^ b
int aInt = Integer.parseInt(a, 2);
int bInt = Integer.parseInt(b, 2);
int xorInt = Integer.parseInt(expected, 2);
byte aByte = (byte)aInt;
byte bByte = (byte)bInt;
byte xorByte = (byte)xorInt;
// conversion routine compacted into single line
byte xor = (byte)(0xff & ((int)aByte) ^ ((int)bByte));
System.out.println(xorInt + " // 11111111 as integer");
System.out.println(xorByte + " // 11111111 as byte");
System.out.println(aInt + " // a as integer");
System.out.println(bInt + " // b as integer");
System.out.println((aInt ^ bInt) + " // a ^ b as integers");
System.out.println(aByte + " // a as byte");
System.out.println(bByte + " // b as byte");
System.out.println(xor + " // a ^ b as bytes");
выводит следующий вывод
255 // 11111111 as integer
-1 // 11111111 as byte
170 // a as integer
85 // b as integer
255 // a ^ b as integers
-86 // a as byte
85 // b as byte
-1 // a ^ b as bytes
вы можете использовать операцию xor для байтов. Это каретка (^).
пример:
byte3[0] = byte1[0] ^ byte2[0];
Java имеет оператор XOR в виде ^
. Просто XOR каждый байт с каждым последующим байтом и поместить их в новый массив.
Это будет работать и для массива байтов одинакового или разного размера.
/** Return XOR of two byte array of different or same size. */
public static byte[] xor(byte[] data1, byte[] data2) {
// make data2 the largest...
if (data1.length > data2.length) {
byte[] tmp = data2;
data2 = data1;
data1 = tmp;
}
for (int i = 0; i < data1.length; i++) {
data2[i] ^= data1[i];
}
return data2;
}