移位操作符、位操作符和整型提升详解
创作时间:
作者:
@小白创作中心
移位操作符、位操作符和整型提升详解
引用
CSDN
1.
https://blog.csdn.net/2402_89035880/article/details/145663791
本文详细介绍了移位操作符、位操作符和整型提升的概念和使用方法。通过具体的代码示例和二进制运算的详细解释,帮助读者理解这些操作符的工作原理。
移位操作符
左移操作符( << )
左移操作符( << )的规则: 左边抛弃,右边补零
#include <stdio.h>
int main()
{
int a = 10;
//00000000000000000000000000001010 -- 10的原码/反码/补码
int b = a << 1;
//a向左移动一位
//移位后
//00000000000000000000000000010100 -- 补码
//00000000000000000000000000010100 -- 原码
//b = 20
printf("a = %d\n", a);
printf("b = %d\n", b);
//a向左移动一位,但a的值不变
return 0;
}
右移操作符( >> )
右移操作符( >> )的规则: 逻辑右移、算术右移
1.逻辑右移: 左边用0填充,右边丢弃
2.算术右移: 左边用原该值的符号位填充,右边丢弃
右移到底是采用逻辑右移还是算数右移是取决于编译器的,
大部分编译器采用算术右移
#include <stdio.h>
int main()
{
int a = -10;
//10000000000000000000000000001010 -- -10的原码
//11111111111111111111111111110101 -- -10的反码
//11111111111111111111111111110110 -- -10的补码
int b = a >> 1;
//a向右移动一位
//1.假设是逻辑右移
//01111111111111111111111111111011 -- 补码
//01111111111111111111111111111011 -- 原码
//可知b是一个非常大的正数
//2.假设是算术右移
//11111111111111111111111111111011 -- 补码
//10000000000000000000000000000101 -- 原码
//b = -5
printf("a = %d\n", a);
printf("b = %d\n", b);
return 0;
}
注意:对于移位运算符,不要移动负数位,这个是标准未定义的。
#include <stdio.h>
int main()
{
int a = 1;
int b = a << -1;//err
return 0;
}
位操作符
按位与( & )
按位与 &
对应的二进制位上,有0就是0,都是1才为1
int main()
{
int a = -8;
int b = 6;
int c = a & b;
//10000000000000000000000000001000 -- -8的原码
//11111111111111111111111111110111 -- -8的反码
//11111111111111111111111111111000 -- -8的补码
//00000000000000000000000000000110 -- 6的原码/反码/补码
//a & b 后
//00000000000000000000000000000000 -- c的原码/反码/补码
//c = 0
printf("c = %d\n", c);
return 0;
}
按位或( | )
按位或 |
对应的二进制位上,有1就是1,都是0才为0
int main()
{
int a = -8;
int b = 6;
int c = a | b;
//10000000000000000000000000001000 -- -8的原码
//11111111111111111111111111110111 -- -8的反码
//11111111111111111111111111111000 -- -8的补码
//00000000000000000000000000000110 -- 6的原码/反码/补码
//a | b 后
//11111111111111111111111111111110 -- c的补码
//10000000000000000000000000000010 -- c的原码
//c = -2
printf("c = %d\n", c);
return 0;
}
按位异或( ^ )
按位异或 ^
对应的二进制位上,相同为0,相异为1
int main()
{
int a = -8;
int b = 6;
int c = a ^ b;
//10000000000000000000000000001000 -- -8的原码
//11111111111111111111111111110111 -- -8的反码
//11111111111111111111111111111000 -- -8的补码
//00000000000000000000000000000110 -- 6的原码/反码/补码
//a ^ b 后
//11111111111111111111111111111110 -- c的补码
//10000000000000000000000000000010 -- c的原码
//c = -2
printf("c = %d\n", c);
return 0;
}
按位异或的特点
a ^ a == 0
0 ^ a == a
a ^ b == b ^ a 支持交换律
按位取反( ~ )
按位取反 ~
0变为1,1变为0
int main()
{
int a = -1;
int b = ~a;
//10000000000000000000000000000001 -- -1的原码
//11111111111111111111111111111110 -- -1的反码
//11111111111111111111111111111111 -- -1的补码
//按位取反操作后
//00000000000000000000000000000000 -- b的原码/反码/补码
//b = 0
printf("b = %d\n", b);
return 0;
}
整型提升
整型提升
1.有符号整数提升是按照变量的数据类型的符号位来提升的,提升的时候高位补符号位
2.无符号整数提升,高位补0
int main()
{
char a = 127;
//00000000000000000000000001111111 int类型的127的原码/反码/补码
//01111111 -> a的原码/反码/补码 截断后
//截断的原因:char类型是8个bit位,32个bit位放不下,所以要截断
char b = 5;
//00000000000000000000000000000101 int类型的5的原码/反码/补码
//00000101 -> b的原码/反码/补码 截断后
char c = a + b;
//整型提升
//char在vs编译器上默认是signed char 所以高位补符号位
//00000000000000000000000001111111 -> 整型提升后的a的补码
//00000000000000000000000000000101 -> 整型提升后的b的补码
//00000000000000000000000010000100 -> 相加后的补码
//10000100 -> c的补码 截断后
printf("%d\n", c);
//%d打印c的值 打印的是signed int 类型,c要整型提升,高位补符号位
//11111111111111111111111110000100 -> 整型提升后的补码
//10000000000000000000000001111011
//10000000000000000000000001111100 -> 原码
//-124
return 0;
}
热门推荐
刘谦张艺兴加盟春晚,你最期待谁?
女生喜欢你,这些身体语言藏不住啦!
女生喜欢你的身体语言,你能读懂几个?
《心动的信号》揭秘女生喜欢人的身体语言
为什么需要终身学习?
职场学习能力的重要性:五大核心价值与提升策略
15个简单可行的家庭理财小技巧
银行短信通知要收费,该取消吗?银行工作人员告诉你答案
杭州新车上牌办理流程+材料说明
圭亚那的阿拉瓦克人:文化传承与现代化的双重奏
智能家居节能方案:利用科技提高家庭能源利用效率
必学!平常人必备的汽车节能驾驶技巧
节能降碳先进技术推动经济社会发展全面绿色转型
绵阳市出租车春节加收5元引发热议:平衡供需还是加重负担?
域名交易手续费400万?网警带你揭秘此类诈骗
优孟衣冠再现,《王的男人》背后的历史真相
《因为爱情有多美》:一部展现都市情感纠葛的电视剧
全员牢记!叉车安全作业十不准
叉车安全管理措施如何制定?
小班儿童如何安全过马路?
这把装备“高端局”,中国制造靠什么赢?
社区这样做,小班儿童过马路更安全
合肥长江路幼儿园:创新教学让交通安全教育更有趣
第四套人民币真假图解:详细鉴别方法与防伪特征
如何正确使用蓝牙耳机与车载系统连接?这种连接方式有哪些潜在的便利和挑战?
《因为爱情》主题曲再引热议:一首歌,一段情,一场关于爱情的思考
梅菜扣肉这样做太香了,大厨看了都点赞!
加里富纳文化:阿拉瓦坎语系的神秘传说
阿拉瓦克人:加勒比海上的消失之谜
《道诡异仙》实体书众筹火爆,装帧设计惊艳