博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
位运算
阅读量:4655 次
发布时间:2019-06-09

本文共 879 字,大约阅读时间需要 2 分钟。

位运算

  • & 按位与
  • | 按位或
  • ^ 按位异或
  • ~ 按位取反
  • << 按位左移
  • >> 按位右移

    用途: 直接操作二进制,省内存,效率高

1)<< 按位左移 各二进位全部左移n位,高位丢弃,低位补0 12演示左移右移

x << n 左移 x 的所有二进制位向左移动n位,移出位删掉,移进的位补零

【注意事项】

a.左移1位相当于 乘以2 用途:快速计算一个数乘以2的n次方 (8<<3 等同于8*2^3)b.左移可能会改变一个数的正负性
2)>> 右移 各二进位全部右移n位,保持符号位不变
x >> n x的所有二进制位向右移动n位,移出的位删掉,移进的位补符号位 右移不会改变一个数的符号右移1位相当于 除以2x 右移 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 进行了取反之后的补码

既然已经知道了补码,那么接下来只要转换为 咱们人能识别的码型就可以,因此按照规则 ,把这个1111   0110 这个补码 转换为原码即可 符号位不变,其它位取反==> 1000  1001 然后+1 ,得到原码   =======>1000 1010   这就是 -10
  • 【扩展】

    1)任何数和1进行&操作,得到这个数的最低位 数字&1 = 数字的二进制形式的最低位

    2)位运算优先级

 

 

 

 

 

 

转载于:https://www.cnblogs.com/loaderman/p/6559822.html

你可能感兴趣的文章
React接入Sentry.js
查看>>
ssh自动分发密匙脚本样板
查看>>
转 小辉_Ray CORS(跨域资源共享)
查看>>
Linux安装postgresql
查看>>
MyBatis启动:MapperStatement创建
查看>>
【 全干货 】5 分钟带你看懂 Docker !
查看>>
[转]优化Flash性能
查看>>
popStar手机游戏机机对战程序
查看>>
lambda表达式树
查看>>
二次注入原理及防御
查看>>
会话记住已登录功能
查看>>
Linux内核分析——可执行程序的装载
查看>>
第一阶段冲刺3
查看>>
父类引用指向子类对象
查看>>
网页如何实现下载功能
查看>>
IT男专用表白程序
查看>>
读《大道至简》第六章感想
查看>>
ef linq 中判断实体中是否包含某集合
查看>>
章三 链表
查看>>
Solution for Concurrent number of AOS' for this application exceeds the licensed number
查看>>