位运算:<<、>>、>>>

2020-07-27  本文已影响0人  122604
<<(左移)          符号位不变,通过从右推入零向左位移,并使最左边的位脱落                 
>>(右移)          符号位不变,通过从左推入最左位的拷贝来向右位移,并使最右边的位脱落           
>>>(无符号右移)    通过从左推入0来向右位移,并使最右边的位脱落        
计算过程
    原码  --->  反码  --->  补码  --->  计算  --->  反码  --->  原码(计算结果) 
下面使用 10-108位二进制 举例说明:
左移(<<)
  10 << 2 = 40

  000 1010 ---> 0000 1010 ---> 0000 1010 ---> 0010 1000 ---> 0010 1000 ---> 0010 1000 ---> 40

  -10 << 2 = -40

  1000 1010 ---> 1111 0101 ---> 1111 0110 ---> 1101 1000 ---> 1101 0111 ---> 1010 1000 ---> -40
右移(>>)
  10>> 2 = 2

  0000 1010 ---> 0000 1010 ---> 0000 1010 ---> 0000 0010 ---> 0000 0010 ---> 0000 0010 ---> 2
  
  -10 >> 2 = -3

  1000 1010 ---> 1111 0101 ---> 1111 0110 ---> 1111 1101 ---> 1111 1100 ---> 1000 0011 ---> -3
无符号右移(>>>)
  10 >>> 2 = 2

  0000 1010 ---> 0000 1010 ---> 0000 1010 ---> 0000 0010 ---> 0000 0010 ---> 0000 0010 ---> 2

  -10 >>> 2 = 67 (结果会根据数据类型发生改变 byte、short、int、long)
  
  1000 1010 ---> 1111 0101 ---> 1111 0110 ---> 0011 1101 ---> 0011 1100 ---> 0100 0011 ---> 67
上一篇 下一篇

猜你喜欢

热点阅读