常用的数据类型有以下7种(由所占字节数的从大到小排列):
double 8字节
long long int 8字节
float 4字节
int 2/4字节
short 2字节
char 1字节
同一种运算符,要求左右的数据类型一样,数据类型转换规则有以下三条:
1. 由窄的数据类型转换为宽的数据类型。
2. short 与 cha r进行运算时,都必须提升为int进行计算。
3. 对同一种数据类型来讲,无符号的数比有符号的数“宽”,应转成无符号的数进行计算。
一:从窄到宽:高位全部补符号位。
eg:
char ch1 = 10 char 类型占1个字节, 其二进制为:0000 1010
要将 ch1 转成 int 类型,int 占4个字节,高位全部补符号位,其二进制形式为:0000 0000 0000 0000 0000 0000 0000 1010,结果还是10。
eg:
char ch2 = -1 char 类型占1个字节, 其二进制为:1111 1111
要将 ch1 转成 int 类型,int 占4个字节,高位全部补符号位,其二进制形式为:1111 1111 1111 1111 1111 1111 1111 1111,结果还是-1.
二:从宽到窄:保留低地址数据,高地址数据截断。
因为PC是小端,低地址保存低数据,因此当数据类型从宽到窄转换时,高位数据截断,保留低位数据。
eg:
char ch = 1000;
printf("%x\n", ch);
程序结果为:e8
1000 的二进制形式为: 0000 0000 0000 0000 0000 0011 1110 1000
它的低位数据为 1110 1000,转换成16进制是e8,与程序结果一致。
程序实例:
# include <stdio.h>
int main()
{
unsigned short a = 10;
unsigned int b = 10;
if(a > -1)
{
printf("a > -1\n");
}
else
{
printf("a < -1\n");
}
if(b > -1)
{
printf("b > -1\n");
}
else
{
printf("b < -1\n");
}
return 0;
}
程序运行结果如上图所示,现进行分析总结:
a 的数据类型为 unsigned short ,-1的数据类型为 signed int ,两者进行比较时 a 需要转换为 signed int 的数据类型,这是由窄到宽的数据类型转换,高位补符号位,即补0, 因此 a 转换后结果还是 10 。10 > -1,所以结果为a > -1 。
b 的数据类型为unsigned int,-1的数据类型为 signed int ,因为同一类型中无符号数要宽于有符号数,因此两者进行比较时 -1 需要转换为 signed int 的数据类型,需要高位补符符号位,即补1, 因此 -1 转换后结果还是个很大的正整数 ,所以结果为b < -1 。