一.整型家族
在C语言中,整型数据有short,int,long,long long和char,这一系列整型是以二进制的方式存放在内存中的,不同的整型表示占用的内存大小不同,因此可以存储的数据大小也不同。
二.原码,反码,补码的概念
原码直接把数据翻译成二进制,反码是原码符号位即首位不变,其它位相反,补码是在反码的基础上加一,正数的原码,反码和补码都是一样的。而数据在内存中都是以补码的形式存储的,这是因为CPU下面只可以进行加法运算
举一个例子来说明:
1-1=0,在CPU中会翻译成1+(-1),然后将补码相加,最后翻译成十进制得出答案,具体过程如下(以32字节为例)
00000000000000000000000000000001 1的补码
11111111111111111111111111111111 -1的补码
两者相加得到 100000000000000000000000000000000 结果为0,如果用原码,最后会得到-2,不是正确的答案。所以说,补码的出现完美解决了这一问题。
本文介绍了C语言中整型数据的不同类型及其内存占用,强调了原码、反码和补码的概念。补码的使用确保了CPU在进行负数加法时能得到正确结果,通过一个32位的示例解释了补码运算的过程。
2190

被折叠的 条评论
为什么被折叠?



