文章目录
1, 左移(<<),右移(>>)
1.1,左移 <<
原码,反码,补码
符号位为第一位
在内存中表示的时补码
反码 = 原码除了符号位以外取反
补码 = 原码除了符号位以外取反在+1
一个正数的原码,反码,补码都一样。
如:10
原码:00000000 00000000 00000000 00001010
反码:00000000 00000000 00000000 00001010
补码:00000000 00000000 00000000 00001010
负数
反码 = 原码符号位不变其余取反
补码 = 反码+1
如:-10
原码:00000000 00000000 00000000 00001010
反码:11111111 11111111 11111111 11110101
补码:11111111 11111111 11111111 11110110
1.2,右移 >>
1,算术右移(较多):右边丢弃,左边补原来的符号位
2,逻辑右移 :右边丢弃,左边补0
2,按位与(&),按位或(|),按位异或(^)
2.1,按位与(&)
对应的二进制位有0则为0,同时为1才为1
2.2按位或(|)
对应的二进制位有1则为1,都为0才为0
2.3 按位异或(^)
对应的二进制位相同为0,相异为1
3,后置++(–),前置++(–)
3.1后置++(先使用,后++)
3.2前置++(先++,在使用)
答案:c(先使用,后++)
4,逻辑与(&&),逻辑或(||)
4.1逻辑与(&&)
int main()
{
int i = 0, a = 0, b = 2, c = 3, d = 4;
i = a++ && ++b && d++;
printf("a = %d\n b = %d\n c = %d\nd = %d\n", a, b, c, d);
return 0;
}
4.2逻辑或(||)
int main()
{
int i = 0, a = 1, b = 2, c = 3, d = 4;
i = a++||++b||d++;
printf("a = %d\n b = %d\n c = %d\nd = %d\n", a, b, c, d);
return 0;
}
5,条件操作符(exp1 ? exp2 : exp3)
int main()
{
int a = 1;
int b = 3;
int c = (a > b ? a : b);
printf("%d\n", c);
return 0;
}
6,逗号表达式(exp1,exp2,exp3,…expN)
逗号表达式,左到右依次执行,表达式的结果是最后一个表达式
7,隐式类型转换
为了获得精度,表达式中的字符和短整型操作数在使用前转换为普通整型,转换成为整型提升
负数的整型提升:高位补1
正数的整型提升:高位补0
8,算术转换