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)*S*M*2^E,其中S为符号位;M为有效数字,表精度;E为指数位。
对于32位,1位符号位,8位指数位,23位有效数字。中间数127(加127)
对于64位,1位符号位,11位指数位,52为有效数字。中间数为1023(加1023)
E全为0时, 表示无穷小;
E全为1时,表示无穷大。