1.数据在内存中的存储
1.1 源码,反码,补码
源码: 直接将二进制按照正负数的形式翻译成二进制就可以
反码:将原码的符号位不变,其他位依次按位取反就可以得到
补码:在反码的基础上加一
ps:在内存中,数据存放的都是补码,因为计算机只有加法器
1.2机器的大小端(重点)
由图可知数据在(vs2008)图中是倒着存的,这就是机器的大小端问题
1.2.1什么是机器的大小端
大端模式存储:数据的低位字节序存储在高地址,数据的高位字节序存储在低地址
小端模式存储:数据的低位字节序存储在低地址,数据的高位字节序存储在高地址
1.2.2为什么要有大小端之分
原因:
C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题
1.2.3怎么判断机器的大小端
百度2015年系统工程师笔试题:
请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序
方法一:强制类型转换一个int型
int CheckSystem()
{
int a = 1;
return (char)a;//*(char*)&a
}
方法二:联合体
int CheckSystem()
{
union A
{
int i;
char c;
};
A a;
a.i = 1;
return a.c;
}
只要返回值为1就是小端存储,为什么呢?请看下图
2.经典的数据存储笔试题
int main()
{
char a = -1;
signed char b = -1;
unsigned char c = -1;
printf("a=%d,b=%d,c=%d", a, b, c);
system("pause");
return 0;
}
答案:1,1,255.
c存到内存中为11111111(char只可以存8个比特位),无符号的整形提升相当于给前面补了24个0,然后直接输出就是255
#include <stdio.h>
int main()
{
char a = -128;
printf("%u\n",a);
return 0;
}
答案:4294967168
存到内存中为10000000,因为是一个有符号的数,所以整形提升相当于给前面补24个1,直接按%u形式打印不考虑原反补,所以输出一个很大的数字
#include <stdio.h>
int main()
{
char a = 128;
printf("%u\n",a);
return 0;
}
答案:4294967168
与上题相同,存到内存中的数字是一样的
int i= -20;
unsigned int j = 10;
printf("%d\n", i+j);
答案:-10
将俩个数字全部转换为补码进行运算
unsigned int i;
for(i = 9; i >= 0; i--)
{
printf("%u\n",i);
}
答案:输出9-0后死循环
因为以%u打印不可能小于零
int main()
{
char a[1000];
int i;
for(i=0; i<1000; i++)
{
a[i] = -1-i;
}
printf("%d",strlen(a));
return 0;
}
7.
short num = 32767;
short int a = num +1;
printf("%d\n",a);
//0111 1111 1111 1111 -> 1000 0000 0000 0000
//(系统直接识别为最小值,不进行解码)
答案:-32768
举个栗子,char a = 128实际上就是-128
3.浮点数在内存中存储(了解)
举个栗子:
int a = -5.5//a在内存中是怎么存的?
写出他的二进制序列?
10000000000000000000000000101.1?
实际上浮点数是这样存的