//key & hash are both byte[]
int leftPos = 0, rightPos = 31;
while(leftPos < 16) {
//possible loss of precision. required: byte, found: int
key[leftPos] = hash[leftPos] ^ hash[rightPos];
leftPos++;
rightPos--;
}
Java の 2 バイトに対するビット演算が int を返すのはなぜですか? キャストしてバイトに戻すことができることはわかっていますが、ばかげているようです。