数据在内存中的存储

一、数据存放在内存中都是以其补码的形式存放的。正数的原码和补码相同,负数的补码为原码除过符号位,其他位取反,并加1获得的
二、数据在内存中存储时,有两种模式:分别为大端机和小端机
小端机模式为低位数据存在低位地址,高位数据存高位地址;
大端机模式为高位数据存低位地址,低位数据存在高位地址中,这种大端机模式能够直接看出当前数据的二进制表示。
如十进制20,其二进制位(00000000 00000000 00000000 00010100)
在小端机模式下,存储为 0x 14 00 00 00
在大端机模式下,存储为 0x 00 00 00 14
三、如何判断一台电脑为大端机仍是小端机模型?
可用***类型强制转换***,将Int数据转化为char数据,这样只会输出低字节的数据,而后判断为大端机仍是小端机。
四、char 等价于signed char , unsigned char 表示无符号的字符。
五、判断输出结果web

#include <stdio.h>
int main()
{
	char a = -1;
	signed char b = -1;
	unsigned char c = -1;
	printf("a=%d,b=%d,c=%d\n", a, b, c);
	system("pause");
	return 0;
}

在这里插入图片描述
分析:
此题考查的是***数据的存储和类型的提高***。对于上述结果a,b的结果毫无疑问,可是c的结果为c=255,这是由于在类型提高的过程当中,unsigned char c = -1提高为有符号的int时,
在这里插入图片描述svg

六、求以下代码输出结果:spa

int main()
{
char a[1000];
int i;
for(i=0; i<1000; i++)
{
a[i] = -1-i;
}
printf("%d",strlen(a));
return 0;
}

在这里插入图片描述
分析:
strlen(a)是在找’\0’,而其ASCII值为0,则实则是为了找a[i]什么时候为全0
在这里插入图片描述
七、浮点型的存储
通式为(-1)*S*M*2^E,其中S为符号位;M为有效数字,表精度;E为指数位。
对于32位,1位符号位,8位指数位,23位有效数字。中间数127(加127)
对于64位,1位符号位,11位指数位,52为有效数字。中间数为1023(加1023)
E全为0时, 表示无穷小;
E全为1时,表示无穷大。3d