位运算符的小总结

六个位运算符& | ^ ~ << >>

&

按位与运算符把二进制短的按照位置与二进制长的进行与运算即 1&1=1 1&0=0 0&0=0

|

按位并运算符把二进制短的按照位置与二进制长的进行并运算即 1|1=1 1|0=1 0|0=0

^

异或运算相同为0,不同为1 1^1=0 0^0=0 1^0=1

~

取反运算把0和1互换 1110 ~ 0001

<<

左移运算把二进制左移相应的位数 110<<1=1100

>>

右移运算把二进制右移相应的位数 110>>1=11

试验代码

#include <bits/stdc++.h>
using namespace std;
int main()
{
  int a,b;
  while(cin>>a>>b)
  {
    cout<<(a&b)<<"\n";
    cout<<(a|b)<<"\n";
    cout<<(a^b)<<"\n";
    cout<<(~a)<<" "<<(~b)<<"\n";
    cout<<(a<<2)<<"\n";
    cout<<(b>>2)<<"\n";
  }
}

试验结果

posted @ 2018-10-24 19:38  baccano!  阅读(212)  评论(0编辑  收藏  举报