C位运算

计算机内部,所有数据被表示为二进制数的序列。位运算符通常用于处理整型操作数的各个数位,通常将数据当做无符号整型来处理。
位运算符有:按位于(&),按位或(|),按位异或(^),左移(<<),右移(>>)和按位取反(~)。
按位与(&)仅当两个操作数相应的二进制数位均为1时,按位与运算结果相应的二进制数位才会被置成1。
按位或(|)如果两个操作数相应的二进制数位至少一个是1,则按位或运算结果相应的二进制数位会被置成1。
按位异或(^)仅当两个操作数相应的二进制数位只有一个是1时,按位异或运算结果相应的二进制数位才被置成1。
按位取反(~)将操作数中所有0的数位置成1,1的数位置成0。
左移(<<)将第一个操作数按位向左移动,移动的位数由第二个操作数指定。右边腾空的数位补0,并不改变第一个操作数的值,返回左移运算后的结果。
右移(>>)将第一个操作数按位向右移动,移动的位数由第二个操作数指定。左边腾空的数位填补方式取决于所使用的计算机,并不改变第一个操作数的值,返回右移运算后的结果。
按位左移运算符的使用(按位显示一个无符号整数):

void displayBits(unsigned);
void displayBits(unsigned value) {
    unsigned mask = 1 << CHAR_BIT * sizeof(unsigned) - 1;
    int counter = 1;
    for (; counter <= CHAR_BIT * sizeof(unsigned); counter++) {
        putchar(mask & value ? '1' : '0');
        value <<= 1;
        if (counter % 8 == 0) {
            putchar(' ');
        }
    }
    putchar('\n');
}

符号常量CHAR_BIT在头文件limits.h中定义,表示一个字节的二进制数的位数。若左移右移位数多余可移动的位数或者为负数时,则无定义。
按位运算后赋值运算符:

&=
|=
^=
<<=
>>=
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值