位运算
位运算
- & 按位与
- | 按位或
- ^ 按位异或
- ~ 按位取反
- << 按位左移
-
>> 按位右移
用途: 直接操作二进制,省内存,效率高
1)<< 按位左移 各二进位全部左移n位,高位丢弃,低位补0 12演示左移右移
x << n 左移 x 的所有二进制位向左移动n位,移出位删掉,移进的位补零
【注意事项】
1 2 | a.左移 1 位相当于 乘以 2 用途:快速计算一个数乘以 2 的n次方 ( 8 << 3 等同于 8 * 2 ^ 3 ) b.左移可能会改变一个数的正负性 |
2)>> 右移 各二进位全部右移n位,保持符号位不变
1 2 3 | x >> n x的所有二进制位向右移动n位,移出的位删掉,移进的位补符号位 右移不会改变一个数的符号 右移 1 位相当于 除以 2 x 右移 n 位就相当于除以 2 的n次方 用途:快速计算一个数除以 2 的n次方 ( 8 >> 3 等同于 8 / 2 ^ 3 ) |
3)& 按位与 全1才1否则0 :只有对应的两个二进位均为1时,结果位才为1,否则为0
4) | 按位或 有1就1 只要对应的二个二进位有一个为1时,结果位就为1,否则为0
5) ^ 按位异或 不同为1 当对应的二进位相异(不相同)时,结果为1,否则为0
6) ~ 取反 ~9 =-10
【为什么9取反变成了-10的说明】: 9的原码 ==> 0000 1001 因为正数的原码=反码=补码,所以在 真正存储的时候就是0000 1001
接下来进行对9的补码进行取反操作 进行取反==> 1111 0110 这就是对9 进行了取反之后的补码
1 2 3 | 既然已经知道了补码,那么接下来只要转换为 咱们人能识别的码型就可以,因此按照规则 ,把这个 1111 0110 这个补码 转换为原码即可 符号位不变,其它位取反 = = > 1000 1001 然后 + 1 ,得到原码 = = = = = = = > 1000 1010 这就是 - 10 |
-
【扩展】
1)任何数和1进行&操作,得到这个数的最低位 数字&1 = 数字的二进制形式的最低位
2)位运算优先级
最后,关注【码上加油站】微信公众号后,有疑惑有问题想加油的小伙伴可以码上加入社群,让我们一起码上加油吧!!!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步