それぞれが4バイト(byte1 []、byte2 [])を含む2バイトの配列があり、それらをXORして新しい4バイト配列(byte3 [])を作成したいのですが、どうすればよいですか?
(または、一度に各バイトを実行してから、それらを新しい配列に配置します)
それらを整数に変換し(損失なし、プリミティブ拡大)、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] = (byte) (byte1[0] ^ byte2[0]);
これは、同じサイズまたは異なるサイズのバイト配列でも機能します。
/** 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;
}
Java には、 の形式の XOR 演算子があり^
ます。各バイトを後続の各バイトと XOR し、それらを新しい配列に入れます。