【C语言】unsigned无符号类型运用的两个实例

前排提醒?

本篇博客是对下一篇博客《char类型在内存中的存放》的拓展

并非对unsigned类型的详解!


示例1

#include <stdio.h>
int main()
{
	int i=-20;
	unsigned int j=10;
	
	printf("%dn",i+j);
	return 0;
 } 

当有符号类型和无符号类型相加的时候,编译器是怎么处理的呢?

10000000 00000000 00000000 00010100  -20的原码
11111111 11111111 11111111 11101011   反码
11111111 11111111 11111111 11101100   补码
00000000 00000000 00000000 00001010   10的补码

-20的补码和10的补码 相加

11111111 11111111 11111111 11110110 得到的补码
11111111 11111111 11111111 11110101 反码
10000000 00000000 00000000 00001010 原码 -10

得到的结果为-10

image-20211214150204180

当我们把j改为-10的时候,编译器依然能给出正确的答案-30

这是因为在计算的时候,编译器先按照补码的形式进行运算,最后%d打印,格式化为有符号整数

  • 数据的存储和类型无关,只有读取的时候有区别

示例2

第二个示例可以让我们了解无符号数在应用时候存在的限制

#include<windows.h>
#include <stdio.h>

int main()
{
	unsigned int i;
	for(i=9;i>=0;i--)
	{
		printf("%un",i);
		Sleep(1000);//更好的观察数据的打印
	}
	return 0;
}

因为这里我们使用的是%u打印无符号数

而无符号数i中不可能出现负数,也就没有小于0的情况(i永远大于等于0)

当i=0后继续–,二进制补码变成如下形式

11111111 11111111 11111111 11111111

因为是无符号数,直接将补码视作原码进行计算

就得出了在窗口中打印的非常大的数字

image-20211216122901387


小结

本篇博客展示了两种无符号数调用的情况

下篇博客讲述char类型在数据中的存储的时候会用到!

最近事情真的挺多的,英语4级、期末考试

高数和线代真的太难了,两座大山压着我?

希望期末不挂科

感谢你看到最后,求点赞关注!

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码

)">
< <上一篇

)">
下一篇>>