移位操作符、位操作符和整型提升详解
创作时间:
作者:
@小白创作中心
移位操作符、位操作符和整型提升详解
引用
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;
}
热门推荐
漫威宇宙最强反派:黑暗维度统治者多玛姆
颜夕宫闱贵妃传历史原型探究
孕妇可以做脸部护理吗?孕期如何安全呵护肌肤?品牌推荐全攻略!
烧烤店的调料不单单是孜然,老师傅教你几招,在家就能吃串串
调控免疫耐受的四类细胞
瓦洛兰特国服开挂现象分析
裁判认为塞瓦略斯对巴里奥斯的犯规较为鲁莽,但不构成红牌
东风随春归,细说“东风”的文化内涵
勇士12人轮换展现冠军相:进攻高效防守凶悍,两战轰下150分创队史纪录
以基础研究支撑科技大厦
可转债投资新策略:低风险+大分散+大轮动
菊花普洱茶:独特外观与细腻风貌的完美融合
双鱼座全解析:性格特质、爱情观及星座配对指南
虚拟内存不足怎么解决?16GB物理内存下虚拟内存设置建议
“四小园”绘出乡村美丽生态新画卷
春天的配色方案:来自春天的实践和灵感
2024年日本投资环境深度分析及中资企业投资策略
怎么样跟老师交流比较好
国内首创!一棵树上可结100多种果蔬,寿命可达20年
媒体:种牙市场乱象纷呈,呼吁更透明的价格标准
智利是否拥有世界级的国家品牌?
数字化驱动下的清廉国企建设:反腐败机制创新与实践
人一定要养面相,让你越来越好看的5个方法!
喝了红茶舌苔变黄了,喝红茶后出现黄色舌苔的原因解析
艺术价值:清代画家朱耷创作的《水木清华图》
男德什么意思(遵守男德什么意思)
选择防火门需注意的材质和填充材料
一篇搞懂数据库的ER模型设计
浴室门反锁了怎么办?教你几招快速解锁方法
斗破苍穹|小医仙……好!软!萧炎错过了!