由于运算符的优先级比+,-的优先级高,而且算术运算是左结合性,所以先做if。在C语言中,不同类型的变量在进行算术运算时,float型的变量要无条件的转化为double型。这样f转化为double(双精度型)型并与也为double(双精度型)的i相乘,得到double(双精度型)的值。之后,算10+‘a"。由于’a’为字符型,C语言规则,字符型数据在参加算术运算是要无条件的转化为int(整形)。这样10+’a’就为整型。最后10+'a’的值与if相加。10+‘a’为整型,if为double(双精度型)。由于double(双精度型)比整形高,所以整型变量自动变为double型。两个double(双精度型)的数相加,和仍为double(双精度型)。类型char->int->unsigned->long->double<-float这样转换的原因是为了尽可能的使得到的结果精度高。一言以蔽之:C语言运算,自动往高精度数据类型转换。