数据类型
1.c语言中的数据类型
数据类型的三个要素:
1】存储数据的宽度
2】存储数据的格式
3】作用范围(作用域)
2.整数类型
char 8BIT 1字节
short 16BIT 2字节
int 32BIT 4字节
long 32BIT 4字节
例如:
void plus(){
char a = 0x12345678;
short b = 0x12345678;
int c = 0x12345678;
long d = 0x12345678;
}
对应的汇编:
mov byte ptr [ebp-4],78h
mov word ptr [ebp-8],offset plus+20h (0040d550)
mov dword ptr [ebp-0Ch],12345678h
mov dword ptr [ebp-10h],12345678h
执行后内存地址的值:
3.整数类型的符号
整数类型分为有符号(signed)和无符号(unsigned)两种;
默认是有符号;
定义无符号数需要在前面加上unsigned;
有符号数和无符号数在内存中存储的方式完全一样,只是在做运算时有差别;
例如:
char a = 0xff;
unsigned char b = 0xff;
对应的汇编指令:
mov byte ptr [ebp-4],0FFh
mov byte ptr [ebp-8],0FFh
可以看出,有符号的-1和无符号的ff,都是以ff保存在内存中;
在运算和比较时,有符号和无符号数转换成的汇编指令会有区别;
如图:有符号数和无符号数在比较时使用了不同的汇编指令;
4.浮点类型
float和double在存储方式上都是遵从IEEE的规范的
float的存储方式如下图所示:
double的存储方式如下图所示:
将一个float型转化为内存存储格式的步骤为:
1、先将这个实数的绝对值化为二进制格式
2、将这个二进制格式实数的小数点左移或右移n位,直到小数点移动到第一个有效数字的右边。
3、从小数点右边第一位开始数出二十三位数字放入第22到第0位。
4、如果实数是正的,则在第31位放入“0”,否则放入“1”。
5、如果n 是左移得到的,说明指数是正的,第30位放入“1”。如果n是右移得到的或n=0,则第30位放入“0”。
6、如果n是左移得到的,则将n减去1后化为二进制,并在左边加“0”补足七位,放入第29到第23位。
如果n是右移得到的或n=0,则将n化为二进制后在左边加“0”补足七位,再各位求反,再放入第29到第23位。
例如: