满意答案
ha0908kuang
2013.09.11
采纳率:46% 等级:12
已帮助:14655人
C语言的类性转换规则,自动转换时是低类型向高类型转换,而强制转换也可以将高类型转换为低类型,但可能造成信息丢失。低类型是内存中占用字节数少的数据类型,即通常所说的窄类型,但是占用相同字节数的数据类型也有高低之分,比如long和unsigned long都占4个字节,但是表达式中同时有long和unsigned long时,先把long转换为unsigned long,然后再参与运算。
参照这个下面关系图来转换:
char和short → int → unsigned int → long → unsigned long → float → double → long double
注意:表达式中的float型变量不会自动转换为double型!!!这一条规则在C89中就已明确。但是很多教材采用了传统C的说法--“float将自动转换为double,然后再参与运算”,这对于理解C语言没有本质的不同,但是却是错误的。
至于你的问题:就是最高类型为float的表达式中,其他类型(也就是上面那个关系图float前面的数据类型)的数据转换为float型数据,例如int*float,则将int转换为float,最后的结果为float型,当然有double类型的表达式中,最后结果为double型
20分享举报