c语言中整型和浮点型混合运算的结果是什么类型
c语言中整型和浮点型混合运算的结果为double型(双精度浮点类型)。
c语言中如果一个运算符两边的运算数类型不同,先要将其转换为相同的类型,即较低类型转换为较高类型,然后再参加运算,转换规则:float(浮点型)转化为double(双精度浮点类型)、int(整型)转为unsigned(无符号整型)转为long(长整型)转为(双精度浮点类型)。
因此,c语言中整型和浮点型混合运算,只能是整型和浮点型同时强制转换为相同的double型(双精度浮点类型)。如两个float型数参加运算,虽然它们类型相同,但仍要先转成double型再进行运算,结果亦为double型。
扩展资料:
在C语言中,自动类型转换遵循以下规则:
1、若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2、转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。若两种类型的字节数不同,转换成字节数高的类型。若两种类型的字节数相同,且一种有符号,一种无符号,则转换成无符号类型。
3、所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4、char型和short型参与运算时,必须先转换成int型。
5、在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度比左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。
参考资料来源:百度百科-C语言类型强制转换
参考资料来源:百度百科-自动类型转换
char , unsigned char 占一个字节
short , unsigned short 占两个字节
int , unsigned int 占四个字节
long , unsigned long 占四个字节(64位编译系统下,占8个字节)
float 单精度浮点 占四个字节
double 双精度浮点 占八个字节
从上到下,数据可表示的范围越来越大,当以上不同种类型数据混合运算时,其运算结果会自动取大范围的数据类型做为结果的数据类型,如:
short + int = int int+float=float long+double=double
因此,整型和浮点型混合运算的结果是 浮点类型!
例如
int i=3;
float j=4.5;
i+j就是double型。
float型数据在运算一律先转换成双精度型,就是double.以提高运算精度。
i要转换成double,因为它和double运算。
http://hi.baidu.com/huifeng00/blog/item/cc99d1d14a5e623f970a16b2.html
上面是我空间里面的,你可以参考下。