--事物的难度远远低于对事物的恐惧!
上一章节我们分析了逻辑运算符 || && !,那么这章我们来分析下位运算符,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、运算优先级:四则运算 > 位运算 > 逻辑运算