数据在内存中的储存
1.整型数据在内存中以补码形式储存
正数:原码,反码,补码相同;
负数:原码为符号位+数值位(符号位为1则为0;符号位为1则为负);
反码为原码除符号位剩余每位按位取反;
补码为反码+1;
从补码到原码依旧按照取反后加一的规则。
本质上内存中储存二进制,VS为了方便展示所储存的是十六进制。
2.大小端介绍
当int,short等类型占据超过1个字节时,如何在内存中存储就显得十分重要,现在通常有2种储存方式,一种为大端字节序存储,一种为小端字节序存储。
首先,我们先介绍字节序的概念:字节序是以字节为单位,讨论存储顺序。
如十六进制0x 11 22 33 44.地址由低到高,若先储存11进入,则为高位储存到低地址,则称为大端字节序存储;若先储存44进入,则为低位储存到低地址,则称为小端字节序存储。
那么,如何通过代码验证一个编译器的储存方式呢?这里给出如下代码。
代码思想:以1为例,1的16进制编码为0x 00 00 00 01,取a的地址,将其强制转换为char*类型,这样只有1个字节,再对其解引用看其所存的值为00还是01即可判断出是大端还是小端储存。
#include <stdio.h>
int check_sys()
{
int a = 1;
return *(char*)&a;
}
int main()
{
int ret = check_sys();
if (ret == 1)
printf("小端\n");
else
printf("大端\n");
return 0;
}
3.符号位区分
我们在代码中经常使用int类型,但其实int在C语言中默认为有符号整型,signed int ==int,所以当我们初步接触C语言时,我们所使用的int均为signed int,与signed int对应的是unsigned int;signed int指有符号整型,unsigned int指无符号整型。符号就指符号位,0为正,1为负。
以下以char类型举例:
unsigned char:从00000000 00000001 00000010...01111110 01111111 1000000...11111110 11111111 而unsigned为无符号,所以unsigned char为0--255的取值范围,因为每一位均为数值位。
signed char:从00000000 00000001 00000010...01111110 01111111 1000000...11111110 11111111而signed为有符号,所以signed char为-128 --127,因为最高位为符号位,所以从01111111到10000000到10000001相当于一个转折点,从127转变为-1。