C++ 不同类型变量进行运算时的类型转换总结

  int型乘以double型,结果是double型(int型转换为double型再运算);
  double型转int型,结果是int型(舍去小数点及其后的数字)。

自动转换遵循以下规则:

  1. 若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
  2. 转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
     a. 若两种类型的字节数不同,转换成字节数高的类型
     b. 若两种类型的字节数相同,且一种有符号,一种无符号,则转换成无符号类型
  3. 所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
  4. char型和short型参与运算时,必须先转换成int型。
  5. 在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。
    例如:
      int 和double属于不同类型,转换遵循低精度到高精度转换,所以int先转成double型就算,计算结果就是double型。
  6. 但是double型转int型不是四舍五入,而是将小数点后的数值全部舍去,如“1.99”转化为int型就变成“1”。
  7. 如果要输出的数据是“xx.0”的形式,C++输出时会自动将“.0”舍去,只输出xx。
参考文献

  [1] https://zhidao.baidu.com/question/1819125247439741468.html

  • 19
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值