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

<<(左移)          符号位不变,通过从右推入零向左位移,并使最左边的位脱落                 
>>(右移)          符号位不变,通过从左推入最左位的拷贝来向右位移,并使最右边的位脱落           
>>>(无符号右移)    通过从左推入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
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。