私はバイナリ文字列を持っているので、結果的にその文字列のいくつかのビットでxor演算を実行したいと思います。 私の文字列は次のとおりです。xor操作を正しく行う方法は?
私は次のコード行を使用して計算を実行しようとしています:
private String ParityCalc(String str){
char[] cA = str.toCharArray();
int[] D = new int[6];
D[0] = D29^cA[0]^cA[1]^cA[2]^cA[4]^cA[5]^cA[9]^cA[10]^cA[11]^cA[12]^cA[13]^cA[16]^cA[17]^cA[19]^cA[22];
D[1] = D30^cA[1]^cA[2]^cA[3]^cA[5]^cA[6]^cA[10]^cA[11]^cA[12]^cA[13]^cA[14]^cA[17]^cA[18]^cA[20]^cA[23];
D[2] = D29^cA[0]^cA[2]^cA[3]^cA[4]^cA[6]^cA[7]^cA[11]^cA[12]^cA[13]^cA[14]^cA[15]^cA[18]^cA[19]^cA[21];
D[3] = D30^cA[1]^cA[3]^cA[4]^cA[5]^cA[7]^cA[8]^cA[12]^cA[13]^cA[14]^cA[15]^cA[16]^cA[19]^cA[20]^cA[22];
D[4] = D30^cA[0]^cA[2]^cA[4]^cA[5]^cA[6]^cA[8]^cA[9]^cA[13]^cA[14]^cA[15]^cA[16]^cA[17]^cA[20]^cA[21]^cA[23];
D[5] = D29^cA[2]^cA[4]^cA[5]^cA[7]^cA[8]^cA[9]^cA[10]^cA[12]^cA[14]^cA[18]^cA[21]^cA[22]^cA[23];
for (int i = 0; i < 6; i++){
if (D[i] == 48){
D[i] = 0;
} else if (D[i] == 49){
D[i] = 1;
}
}
StringBuilder parity = new StringBuilder();
parity.append(D[0]).append(D[1]).append(D[2]).append(D[3]).append(D[4]).append(D[5]);
D29 = D[4];
D30 = D[5];
return parity.toString();
}
私は最終的にパリティに取得しています結果は次のとおりです。100000 正しい結果は次のようになります。001001.
D29とD30は前回の計算からのパリティビットで、どちらも整数です。
何が間違っているのですか?どのように修正できますか?私はおそらくbitwise操作としてそれを行う必要がありますが、私はそれを把握することはできません。 ご協力いただければ幸いです。
なぜ文字列を整数に変換してもう一度やりますか? –
は、演算がいくつかのビットで連続しているためです。どのようにそれを行うsujestですか? –
まず、元のバイナリ文字列を整数に変換することができ、抽出される特定のビットを別の整数に構築することもできます。場合によります。 –