数据在内存中的存储

倖福魔咒の 提交于 2019-12-02 12:55:33

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

#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时,
在这里插入图片描述

6、求如下代码输出结果:

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
在这里插入图片描述
7、浮点型的存储
通式为(-1)SM*2^E,其中S为符号位;M为有效数字,表精度;E为指数位。
对于32位,1位符号位,8位指数位,23位有效数字。中间数127(加127)
对于64位,1位符号位,11位指数位,52为有效数字。中间数为1023(加1023)
E全为0时, 表示无穷小;
E全为1时,表示无穷大。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!