移位操作符
我们用8位的来意思一下
顾名思义,移位操作就是将数据的位向左或者是向右移动。
左移时:值最左边的数将被丢弃,右边多出来的由0补充
右移时:逻辑移位,将左边移入的数用0填充
我们用8位的数据意思一下
超出了边界的话,就自动舍弃掉,没超出边界就不会舍弃
位操作符
- AND(&) a&b 如果都为1,结果为1,否则为0
- OR(|) a|b 有一个为1就为1 ,都是0则为0
- XOR(^) a^b a、b不同则为1,相同为0
样例:将二进制为1001010的数的第bit_number位(位数从右向左数,第0位开始)变为1
value = value | 1 << bit_number
等同于value |= 1 << bit_number
将value的第bit_number位变成0
value &= ~(1 << bit_number)
练习:计数一个值中(二进制)值为1的位的个数
int count_one_bit(unsigned value)
{
int ones;
for (ones = 0; ones != 0; ones >>= 1)
{
if ((value & 1) != 0) { //最右边的位是1
ones += 1;
}
}
}
赋值
赋值也是一个表达式,会返回一个值。
a = x = y + 3
等同于
x = y + 3;
a = x;
因此上面的表达式:a = (x = y + 3)
r = s + (t = u - v) / 3;
等同于
t = u - v;
r = s + (t / 3)
三目运算符号
expr1?a:b
如果expr1返回值是true,那么表达式的值就是a,否则表达式的值是b
算术转换
低优先级的会自动转化为高优先级的值类型
double pi = 3.14;
int r = 5;
cout << pi * r <<endl;(15.7)