C语言中位运算符分析

--事物的难度远远低于对事物的恐惧!

    上一章节我们分析了逻辑运算符 || && !,那么这章我们来分析下位运算符,C语言中的位运算符直接对bit位进行操作,其效率最高,而在C语言中常见的位运算符如下:

    

    其中左移和右移有一下几个注意点:

    -左移操作数必须为整数类型

        -char和short被隐式转换为int后进行移位操作

    -右操作数的范围必须为:[ 0, 31]

    -左移运算符 << 将运算数的二进制位左移

        -规则:高位丢弃,低位补0

    -右移运算符 >> 将运算数的二进制位右移

        -规则:高位补符号位,低位丢弃

下边来看看如下的代码输出什么:

#include <stdio.h>

int main()
{
    printf("%d\n", 3 << 2); 
    printf("%d\n", 3 >> 1); 
    printf("%d\n", -1 >> 1); 
    printf("%d\n", 0x01 << 2 + 3);
    
    // printf("%d\n", 3 << -1); // oops!移位操作数必须为整形,这里不能为-1,(移-1位?这个计算机可弄不了)
    
    return 0;
}

输出结果如下:

从结果上看,0x01 << 2 + 3 等价于  0x01 << (2 + 3),即算术运算符的优先级高于位运算符,对于按位运算符,还有如下几点需要注意:

    -避免位运算符、逻辑运算符、数学运算符同时出现在一个表达式中

    -当位运算符、逻辑运算符、数学运算符需要同时出现在一个表达式中时,尽量使用括号()来表达计算次序

对于位运算符,有一个小技巧:

    -左移n位相当于乘以2的n次方,效率比数学运算符高

    -右移n位相当于除以2的n次方,效率比数学运算符高

 

位运算与逻辑运算的比较:

    -位运算没有短路规则,每个操作数都参与运算

    -位运算的结果为整数,而不是0或1

    -位运算优先级高于逻辑运算优先级    

来看一段混淆是非的代码,下边的执行结果会是什么?

#include <stdio.h>

int main()
{
    int i = 0;
    int j = 0;
    int k = 0;
    
    if( ++i | ++j & ++k )
    {
        printf("Run here...\n");
    }
    
    return 0;
}

总结:

    1、位运算只能用于整数类型

    2、左移和右移运算符的右操作数范围必须为[0, 31]

    3、位运算没有短路规则,所有操作数都会求值

    4、位运算的效率高于四则运算和逻辑运算

    5、运算优先级:四则运算 > 位运算 > 逻辑运算 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值