C++位运算,位取反,位左移,位右移

#include
using namespace std;
int main()
{
unsigned char bits=0227;/采用位操作运算时,要采用无符号数进行运算,
因为C语言和C++没有明确的标准规定位操作如何处理符号位,
所以当我们在使用位操作的时候不要用带符号的类型,要用没符号的类型
/
/0227为8进制数,去掉前面的0就是十进制,也可以在前面增加0X为16进制/
bits=~bits;/对bits进行位操作取反//八进制0227二进制为10010111对应十进制为151.位取反后对应的二进制为01101000对应的十进制为104/
cout<<“10010111取反的结果为:”<<(int)bits<<endl;/运行的结果为104//bits前加(int)是将前面的unsigned类型转换/

bits=bits<<1;/*01101000左移一位的结果为11010000对应的十进制应该为208*/
cout<<"左移一位的结果为:"<<(int)bits<<endl;

bits=bits>>1;/*11010000右移一位的结果为01101000对应的十进制应该为104*/
cout<<"右移一位的结果为:"<<(int)bits<<endl;

bits=bits<<2;/*01101000左移2位的结果为10100000对应的十进制应该为160*/
cout<<"左移两位的结果为:"<<(int)bits<<endl;

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值