c语言中整型和浮点型混合运算的结果为double型(双精度浮点类型)。 c语言中如果一个运算符两边的运算数类型不同,先要将其转换为相同的类型,即较低类型转换为较高类型,然后再参加运算,转换规则:float(浮点型)转化为double(双精度浮点类型)、int(整型)转为unsigned(无符号整型)转为long(长整型)转为(双精度浮点类型)。
因此,c语言中整型和浮点型混合运算,只能是整型和浮点型同时强制转换为相同的double型(双精度浮点类型)。
如两个float型数参加运算,虽然它们类型相同,但仍要先转成double型再进行运算,结果亦为double型。