7

それぞれが4バイト(byte1 []、byte2 [])を含む2バイトの配列があり、それらをXORして新しい4バイト配列(byte3 [])を作成したいのですが、どうすればよいですか?

(または、一度に各バイトを実行してから、それらを新しい配列に配置します)

4

4 に答える 4

13

それらを整数に変換し(損失なし、プリミティブ拡大)、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
于 2013-08-21T16:43:05.787 に答える
6

バイトに対して xor 操作を使用できます。キャレットです(^)。

例:

byte3[0] = (byte) (byte1[0] ^ byte2[0]);
于 2012-12-22T01:52:08.390 に答える
1

これは、同じサイズまたは異なるサイズのバイト配列でも機能します。

   /** 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;
    }
于 2015-12-03T15:52:04.017 に答える
0

Java には、 の形式の XOR 演算子があり^ます。各バイトを後続の各バイトと XOR し、それらを新しい配列に入れます。

于 2012-12-22T01:51:55.497 に答える