在C语言中,无论是函数、数组、整型和浮点型、结构体和联合体,都是存放在内存的某个空间中,本文就稍微深入的介绍一下C语言中这些数据是如何存放的。
文章目录
一、整型的存储
众所周知,数据在计算机中是以二进制存放的,举个例子,10这个整数的二进制表达为1010,在之前我们了解到,整型在C语言中占四个字节也就是32个比特位,所以10这个整数存放的应该是 00000000000000000000000000001010
这个二进制序列。
那么负数又是怎么存储的呢,在此引入一个“原码,反码,补码”的概念,原码即是本身的二进制数字;反码是原码的符号位不变(第一位),其它位取反;补码是在反码的基础上进行 + 1。
正整数的原、反、补码相同,因此,在计算机系统中,存储的数据都是存的补码。由此我们可以得到-10的存储方式
1000 0000 0000 0000 0000 0000 0000 1010//-10的原码
1111 1111 1111 1111 1111 1111 1111 0101//-10的反码
1111 1111 1111 1111 1111 1111 1111 0110//-10的补码
在此我们可以得出它在内存中的16进制序列了,即0xFFFFFFF6,显然此时我们的整型是一个带符号的整型,那如果是unsigned int类型的无符号整型呢?我们可以用-10来试一下:
int main