zoukankan      html  css  js  c++  java
  • (运算符)<< 运算符

      左移运算符 (<<) 将第一个操作数向左移动第二个操作数指定的位数。 第二个操作数的类型必须是一个 int 或具有向 int 的预定义隐式数值转换的类型。

      备注

      如果第一个操作数是 int 或 uint(32 位数),则移位数由第二个操作数的低 5 位给出。 也就是实际的 shift 计数为 0 到 31 位。

      如果第一个操作数是 long 或 ulong(64 位数),则移位数由第二个操作数的低 6 位给出。 也就是实际的 shift 计数为 0 到 63 位。

      不在移位后第一个操作数类型范围内的任意高序位均不会使用,低序空位用零填充。 移位操作从不导致溢出。

      用户定义的类型可重载 << 运算符(请参见操作数);第一个操作数的类型必须为用户定义的类型,第二个操作数的类型必须为 int。 重载二元运算符时,也会隐式重载相应的赋值运算符(如果有)。

      示例

      
     1 class MainClass11
     2 {
     3     static void Main()
     4     {
     5         int i = 1;
     6         long lg = 1;
     7         // Shift i one bit to the left. The result is 2.
     8         Console.WriteLine("0x{0:x}", i << 1);
     9         // In binary, 33 is 100001. Because the value of the five low-order
    10         // bits is 1, the result of the shift is again 2. 
    11         Console.WriteLine("0x{0:x}", i << 33);
    12         // Because the type of lg is long, the shift is the value of the six
    13         // low-order bits. In this example, the shift is 33, and the value of
    14         // lg is shifted 33 bits to the left.
    15         //     In binary:     10 0000 0000 0000 0000 0000 0000 0000 0000 
    16         //     In hexadecimal: 2    0    0    0    0    0    0    0    0
    17         Console.WriteLine("0x{0:x}", lg << 33);
    18     }
    19 }
    20 /*
    21 Output:
    22 0x2
    23 0x2
    24 0x200000000
    25 */
    View Code

      注释

      请注意,i<<1 和 i<<33 给出的结果相同,因为 1 和 33 的低序 5 位相同。

  • 相关阅读:
    HDU5620 KK's Steel(C++语言版)
    HDU5620 KK's Steel(C语言版)
    大整数分解算法
    大整数分解算法
    HDU1319 POJ1595 UVA406 UVALive5490 ZOJ1312 Prime Cuts【素数筛选+打表】
    HDU1106 排序
    B00004 atoi函数
    B00004 atoi函数
    HDU1262 寻找素数对
    HDU1262 寻找素数对
  • 原文地址:https://www.cnblogs.com/gamerLin/p/4446751.html
Copyright © 2011-2022 走看看