ビット演算は、int
(符号付き)の値を返します。符号付き整数は、負数を表すためにの2の補数を使用します。符号拡張は、バイトからintに行くときに使用されます。
byte a = 1; // 0b00000001
int notA = ~a; // 0b11111110 = -128 + 64 + 32 + 16 + 8 + 4 + 2 = -2 (actually 0b11111111 11111111 11111111 11111110)
byte b = 9; // 0b00001001
int notB = ~9; // 0b11110110 = -128 + 64 + 32 + 16 + 4 + 2 = -10 (actually 0b11111111 11111111 11111111 11110110)
バイトに戻ってキャストすると、あなたが先行ビットも反転していることを忘れてしまった0b11110110
byte notB = unchecked((byte)(~b)); // 0b11110110 = 128 + 64 + 32 + 16 + 4 + 2
Console.WriteLine(notB); // 246
「バイト」は8ビットであることが分かります。したがって、バイナリ表現は9で、0b00001001ですか? – Timbo
-2は実際には大丈夫です。なぜなら、intsは...よく使うので、@knittlはちょうどそれを以下に述べました。 – Shark
これはC#に固有のものではなく、CPU自体がこのように動作します –