2016-06-17 44 views
2

为什么C#的按位运算符NOT返回(the_number*-1)-1C#NOT(〜)位运算符返回负值

byte a = 1; 
Console.WriteLine(~a); //equals -2 
byte b = 9; 
Console.WriteLine(~b); //equals -10 
// Shouldn't a=0 and b=6? 

我该如何在C#中执行此操作?

9 = 0b1001 -> NOT 
    = 0b0110 = 6 
+4

你知道'byte'有8位,因此二进制表示为9是0b00001001? – Timbo

+0

-2实际上是正常的,因为ints使用...呃,@ knittl只是在下面说的。 – Shark

+0

这不是特定于C#的CPU本身以这种方式工作 –

回答

6

按位运算返回值为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 
2

你忘了前面几位也倒“预期”的结果:

00001001 
NOT 
11110110 

它看起来像你想到面膜那些:

byte b = 9; 
Console.WriteLine(~b & 0xf); // should output 6