C语言操作符(个人笔记)

本文详细解释了整数的二进制表示形式(原码、反码和补码),以及在C语言中整型提升的概念,重点讨论了算术和逻辑右移的区别,以及字符和短整型在运算中的处理方式。
摘要由CSDN通过智能技术生成

整数的二进制表示形式有3种:原码,反码,补码
原码:把一个数按照正负直接翻译成二进制就是原码
反码:原码的符号位不变,其他位按位取反就是反码
补码:反码+1
正整数的原码,反码,补码是相同的
负整数的原码,反码,补码是要计算的
整数在内存中存储的是:补码(2进制)
在这里插入图片描述
在进行 << , >> , & , ^ , | 操作符进行二进制运算时都应该用补码进行运算,而在打印在显示屏上的时候,应该将补码再转换成原码进行展示

右移操作符:
1.>>算术右移:右边丢弃,左边用原来的符号位来填充
2.>>逻辑右移:右边丢弃,左边直接用0填充
然而到底是算术右移?还是逻辑右移,是取决于编译器的!
VS上是算术右移

&& 操作符左边为假,右边不再计算(不再运行代码,也就报废)
|| 操作符左边为真,右边不再计算(不再运行代码,也就报废)

C的整型算术运算总是至少以缺省整型类型的精度来进行的。
为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。

int main()
{
	char a = 3;
	//00000000000000000000000000000011
	//00000011-截断
	char b = 127;
	//00000000000000000000000001111111
	//01111111-截断
	
	char c = a + b;
	//00000000000000000000000000000011
	//00000000000000000000000001111111
	//00000000000000000000000010000010
	//10000010 - c
	//整型提升
	printf("%d\n", c);
	//11111111111111111111111110000010
	//11111111111111111111111110000001
	//10000000000000000000000001111110
	//-126

	return 0;
}

b和c的值被提升为普通整型,然后再执行加法运算。
加法运算完成之后,结果将被截断,然后再存储于a中。

//负数的整形提升
char c1 = -1;
变量c1的二进制位(补码)中只有8个比特位:
1111111
因为 char 为有符号的 char
所以整形提升的时候,高位补充符号位,即为1
提升之后的结果是:
11111111111111111111111111111111
//正数的整形提升
char c2 = 1;
变量c2的二进制位(补码)中只有8个比特位:
00000001
因为 char 为有符号的 char
所以整形提升的时候,高位补充符号位,即为0
提升之后的结果是:
00000000000000000000000000000001
//无符号整形提升,高位补0
  • 13
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

索隆43

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值