c语言 赋值过程中的类型转换

如果赋值运算符两侧的类型一样,则直接进行赋值,当赋值运算符两侧的类型不一样时,在赋值时要进行类型转换,转换是由系统自动进行进行的,规则如下:

(一)把浮点型数据赋值给整型变量时,要先进行取整操作(去掉小数部分),然后再赋值给整型变量。假设a为整型变量,执行a = 4.7后,a = 4 。

(二)将整型数据赋值给浮点型变量时,会将整型数据以浮点数的形式赋值给变量。假设b为单/双精度实数,执行 b = 4 后,b = 4.0   会以单/双精度实数形式来存储。

(三)将单精度赋值给双精度变量时,内存变为双精度类型存储大小,数值不变,有效位数扩展到15位,将双精度数据类型赋值给单精度变量时,先将双精度数转换为单精度,即只取6~7位有效数字。应注意双精度数值的大小不能超过单精度型变量的数值范围

(四)字符型数据赋值给整型变量时,将字符的ASCLL代码赋给整型变量。例如 :i ='A'   =>     i = 65

  (五)将一个占字节多的整型数据赋给一个占字节少的整型变量时(例如把int 赋值给short),只将其低字节原封不动的赋给变量(即发生截断)。

在进行赋值时,尽量避免将字节多的数据赋值给字节少的数据,因为赋值后数据可能会出现失真,如果一定要赋值,应当保证赋值后数值不会发生改变,即所赋的值在变量的允许数值范围内。

猜你喜欢

转载自blog.csdn.net/qq_27485531/article/details/80789322
今日推荐