Java左移 和 右移 > >

本文深入讲解了位运算符中的左移(<<)和右移(>>)操作,通过实例演示了两种计算方式:一是二进制位直接移动,二是快速算法即乘除以2的幂次。并特别指出对于单数右移时,结果为取整商。

左移<<

什么是左移?
左移运算符“<<” — 使指定值的所有位都左移规定的次数
比如:有一个整数:10 << 2

  1. 第一种计算方式:
    10的二进制八位为 0000 1010,而所有位都左移2次 变为 0010 1000,转为十进制的数为:40

  2. 第二种计算方式:
    第二种计算方式是快速的算法: 左移几次就是乘以 2的几次方,比如:10 << 2 , 10*4=40

右移>>

什么是右移?
右移运算符“>>” - 使指定值的所有位都右移规定的次数。
比如:有一个整数:20 >> 2
1. 第一种计算方式:
20的二进制八位为 0001 0100,而所有位都右移2次 变为0000 0101,转为十进制的数为:5
2. 第二种计算方式:
第二种计算方式是快速的算法: 右移几次就是 除以 2的几次方,比如:20>>2 , 20÷4=5
注意: 如果是单数,也就是二进制末位为1,则结果是将m除以2的n次方的整数商。
比如:5>>2 将5除以2的2次方的取整数商结果为:1。
比如:5>>1 将5除以2的1次方的取整数商结果为:2。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值