但是占用相同字节数的数据类型也有高低之分,比如long和unsigned long都占4个字节,但是表达式中同时有long和unsigned long时,先把long转换为unsigned long,然后再参与运算。例如int*float,则将int转换为float,最后的结果为float型
2.char和short → int → unsigned int → long → unsigned long → float → double → long double 注意:表达式中的float型变量不会自动转换为double型!!!这一条规则在C89中就已明确。但是很多教材采用了传统C的说法——“float将自动转换为double,然后再参与运算”,这对于理解C语言没有本质的不同,但是却是错误的。
3.c语言中float和float型相乘得什么类型?
为避免丢失精度,结果类型提升为double类型。其中的运算包括所有数学运算,即加减乘除。
如两个很大的float数相乘,或两个绝对值很小的float数相乘,前者可能导致溢出,而后者则可能出现数值过小超出float表示范围。
4.不同数据类型的字节数,随编译器不同而不同。
16位编译器: char :1个字节
char*(即指针变量): 2个字节
short int : 2个字节
int: 2个字节
unsigned int : 2个字节
float: 4个字节
double: 8个字节
long: 4个字节
long long: 8个字节
unsigned long: 4个字节
32位编译器: char :1个字节
char*(即指针变量): 4个字节(32位的寻址空间是2^32, 即32个bit,也就是4个字节。同理64位编译器)
short int : 2个字节
int: 4个字节
unsigned int : 4个字节
float: 4个字节
double: 8个字节
long: 4个字节
long long: 8个字节
unsigned long: 4个字节
64位编译器: char :1个字节
char*(即指针变量): 8个字节
short int : 2个字节
int: 4个字节
unsigned int : 4个字节
float: 4个字节
double: 8个字节
long: 8个字节
long long: 8个字节
unsigned long: 8个字节