C语言常规算数转换

C99标准6.3.1.8翻译

有些需要算数类型操作符的操作数可能带来转换,并以类似的方式得到结果类型。目的在于为操作数和确定一种通用的真实类型。对于给定的操作数,各操作数会转换为另一个类型(不改变类型域),其相应的真实类型为通用真实类型。除非另外明确说明,否则通用的真实类型也是结果的真实类型,如果操作数相同并且很复杂,那么结果的类型域就是操作数的类型域。这种模式称为常规算数转换。

1.若其中一个操作数为long double,则无需改变类型域,另一个操作数转化为long double;

2.否则如果其中一个操作数为double,则无需改变类型域,另一个操作数转化为double;

3.否则如果其中一个操作数为float,则无需改变类型域,另一个操作数转化为float;

4.否则将对两个操作数都进行整数升级,在升级的操作数应用一下规则:

    1)如果两个操作数为同一类型,则无需继续转换;

    2)否则如果两个操作数同为有符号或同为无符号整数,则等级较低者向等级较高者转换;

    3)否则如果无符号整数的等级大于等于有符号整数,则将有符号整数转化为无符号整数;

    4)否则,如果有符号整数能够表示无符号整数的所有范围,则将无符号整数转化为有符号整数;

    5)否则根据有符号操作数的类型,将两个操作数都转化为无符号操作数。

转载于:https://www.cnblogs.com/cai2007/p/4590740.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值