1.3 C语言表达式中数据类型的自动转换

C语言允许在一个表达式中出现多种数据类型,在进行运算时,不同类型的数据首先按规则进行类型转换,然后进行运算。

规则如下:

1).若参与运算量的类型不同,则先转换成同一类型,然后进行运算
2).转换按数据长度增加的方向进行,以保证精度不降低。
例如:int类型鹤long类型运算时,先把int量转成long型后再进行运算
3).所有的实数运算都是以双精度进行的,即使仅含flaot单精度量运算的表达式,也要先转换成doubule型,再作运算
4).char型和short型参与运算时,先转换成int型
5).在赋值运算中,赋值号两侧量的数据类型不同时,赋值号右侧量的类型将转换为左侧变量的类型,当右侧量的数据类型长度比左侧变量的数据类型长度大时,会降低精度。

数据类型自动转换图

箭头方向只表示数据类型级别的高低,由低向高转换,并非表示逐级转换,千万不要理解为:int型先转换成unsigned型,再转成long型,再转册灰姑娘double型。
1.3 C语言表达式中数据类型的自动转换_第1张图片

图中横向向右的箭头表示必定的转换:char型,short型在运算时都先转换成int型,float型数据在运算时会先转换成双精度型,以提高运算精度

总结

表达式自动数据类型转换的结果,是将表达式最终转换为表达式中占用存储长度最大的那种数据类型,目的是减少运算过程中的精度损失

你可能感兴趣的:(C语言学习,c语言)