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;
    }