了解班次操作员

Sar*_*a S 19 c#

我无法理解这个移位运算符(c#reference):

class MainClass1
{
 static void Main()
    {
        int i = 1;
        long lg = 1;
        Console.WriteLine("0x{0:x}", i << 1);
        Console.WriteLine("0x{0:x}", i << 33);
        Console.WriteLine("0x{0:x}", lg << 33);
    }
}

/*
Output:
0x2
0x2
0x200000000
*/

class MainClass2
{
     static void Main()
     {
         int a = 1000;
         a <<= 4;
         Console.WriteLine(a);
     }
}

/*
Output:
16000
*/
Run Code Online (Sandbox Code Playgroud)

Mar*_*ell 47

<<是左移算子; 这将获取值的二进制表示,并将所有位"n"位置向左移动("mod"除外,参见"1"),用零回填.

>>是右移的运营商; 这几乎完全相反(向右移动),除了有符号值(即那些可以是负数),它用负值反向填充1,否则为0.

1:

移位运算符基本上是"修改"数据的宽度.int是32位,因此左移33(在Int32中)与左移1完全相同.您不会得到全零.A long是64位,因此33的左移给出不同的答案(原始时间为2 ^ 33).

2:

每个左移(在数据宽度内)与x2相同(对于整数) - 因此<< 4是x2x2x2x2 = x16.

这是简单的二进制:

0000000001 = 1
Run Code Online (Sandbox Code Playgroud)

<<去

0000000010 = 2
Run Code Online (Sandbox Code Playgroud)

<<去

0000000100 = 4
Run Code Online (Sandbox Code Playgroud)

<<去

0000001000 = 8
Run Code Online (Sandbox Code Playgroud)


Jon*_*eet 9

只是为了扩展Marc的答案(Marc,随意将其包括在你的内容中,我将删除这个答案)这在规范的第7.8节中有详细说明:


下面列出了预定义的移位运算符.

向左移:

  • int operator <<(int x,int count);
  • uint operator <<(uint x,int count);
  • long运算符<<(long x,int count);
  • ulong operator <<(ulong x,int count);

<<运算符将x向左移位如下所述计算的位数.

x的结果类型范围之外的高位被丢弃,剩余的位向左移位,低位空位位置被设置为零.

右移:

  • int operator >>(int x,int count);
  • uint operator >>(uint x,int count);
  • long operator >>(long x,int count);
  • ulong operator >>(ulong x,int count);

>>运算符将x向右移位如下所述计算的位数.

当x的类型为int或long时,x的低位被丢弃,其余位向右移位,如果x为非负,则高位空位位置设置为0,如果x为非负值则设置为1是否定的.

当x是uint或ulong类型时,x的低位被丢弃,其余位被右移,高位空位被设置为零.

对于预定义的运算符,要移位的位数计算如下:

当x的类型是int或uint时,移位计数由计数的低5位给出.换句话说,移位计数是从count&0x1F计算的.

当x的类型为long或ulong时,移位计数由计数的低6位给出.换句话说,移位计数是从count&0x3F计算的.

如果得到的移位计数为零,则移位运算符只返回x的值.