C语言中的隐式类型转换

隐式类型转换一直困惑了本人很久,今天终于抽出了时间对其进行了梳理和总结,并且对其有了清楚的认识。现在整理出来和大家分享,希望更多的人能了解其中的奥秘!:)


所谓隐式类型转换就是在编译时由编译程序按照一定规则自动完成,而不需人为干预。因此,在表达式中如果有不同类型的数据参与同一运算时,编译器就在编译时自动按照规定的规则将其转换为相同的数据类型。

C语言规定的转换规则是由低级向高级转换。例如,如果一个操作符带有两个类型不同的操作数时,那么在操作之前行先将较低的类型转换为较高的类型,然后进行运算,运算结果是较高的类型。更确切地说,对于每一个算术运算符,则遵循图1所示的规则。


图1.数据类型转换规则之一

注意:在表达式中,所有的float类型都转换为double型以提高运算精度。

在赋值语句中,如果赋值号左右两端的类型不同,则将赋值号右边的值转换为赋值号左边的类型,其结果类型还是左边类型。

因为函数参数是表达式,因此,当参数传递给函数时,也发生类型转换。具体地说,char和short均转换为int;float转换为double。这就是为什么我们把函数参数说明为int和double,尽管调用函数时用char和float .

也可以将图1所示的规则用图2表示。图2中的水平箭头表示必定转换,纵向箭头表示两个操作对象类型不同时的转换方向。

图2  数据类型转换规则之二

下面举行说明类型转换的规则。例如执行:

x=100+'a'+1.5 *u+f/'b'-s * 3.1415926

其中,u为unsigned型,f为float型,s为short型,x为float型。式中右面表达式按如下步骤处理:

(1)首先将'a'、'b'和s换成int,将1.5和f转换为double型。

(2)计算100+'a',因'a'已转换为int型,于是此运算结果为197。

(3)计算1.5*u,由于1.5已转换为double,u是unsigned型,于是首先u转换为double,然后进行运算,运算结果为double。

(4)计算197+1.5 * u,先将197转换为double(如197.00…00),其结果为double。

(5)计算f/ 'b',f已转换为double,'b'已转换为int,于是先将'b'再转换为double,其结果为double。

(6)计算(197+1.5 * u)+f / 'b',者均为double,于是结果也为double。

(7)计算s * 3.1415926,先将s由int转换为double,然后进行运算,其结果为double。

(8)最后与前面得的结果相减,结果为double。

(9)最后将表达式的结果转换为float并赋给x。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值