c语言整数除法转换成浮点型,C语言中的类型转换

在C语言中不同类型的数据也可以使用二元运算符进行运算,不过如果不明白其中的规律的话,编出来的程序就会有些危险了。

强制类型转换

自动转换类型

举个例子:

/*测试数据的类型转换*/

#include

int main(void)

{

float num0 = 0.0;

int num1 = 64400;

num0 = num1 / 150;

printf("%f", num0);

return 0;

}

结果:

19af928e1fe187d3c4331555a0ad1438.png

按正常计算,num0应该等于429.333,可是按照上面的运算的话,结果是429,那.333去哪里了?眼前这个.333看起来是有些不起眼,但后面还有大量运算的话,这就不是小错误了,我们要严谨地学习C语言,现在就要把那丢失的部分找回来!

因为num1是整数类型,而150也是个整数,所以计算得到的结果也是整数类型,于是计算机将除法得到的结果四舍五入成了一个整数。可以用以下方法解决:

#include

int main(void)

{

float num0 = 0.0;

int num1 = 64400;

num0 = (float)num1 / 150;

printf("%f", num0);

return 0;

}

结果:

8ba8a4081e68bb9a2e7a6528871b1bbb.png

在num1前面加上(float)把num1强制转换成浮点类型变量,结果就是正确的。在C语言中可以将一种类型显式地转换成另一种类型,这个过程称为强制类型转换(cast)

只有两个操作数的类型相同,计算机才能执行二元算术操作(加,减,乘,除和取模)。在二元算术运算中使用不同类型的操作数,编译器就会把其中一个值域较小的操作数类型转换为另一个操作数类型,这称为隐式类型转换(implicit conversion)。再看看前面的计算表达式:

num0 = num1 / 150;

它计算为64400(int) / 150(int),结果是429(int),再将 int 转换成 float 得到429.0000.

只要算术表达式中有混合类型的变量,C编译器就会使用一组特殊的规则,确实表达式如何计算。下面就介绍这些规则。

隐式类型转换的规则

确定二元运算中的哪个操作数要转换为另一个操作数的类型时,其机制相当简单。其基本规则是,值域较小的操作数类型转换为另一个操作数类型,但在一些情况下,两个操作数都要转换类型。

为了准确地表述这些规则,需要比上述更复杂的描述,所以可以忽略一些细节,在以后需要时再考虑他们。

编译器按顺序采用如下规则,确定要使用的隐式类型转换:

如果一个操作数的类型是long double,把另一个操作数类型转换为long double类型。

否则,如果一个操作数的类型是double,就把另一个操作出类型转换为double类型。

否则,如果一个操作数的类型是float,就把另一个操作数类型转换为float类型。

否则,如果两个操作数的类型都是带符号的整数或无符号的整数,就把级别较低的操作数类型转换为另一个操作数的类型。无符号整数类型的级别从低到高为:

signed char, short, int, long, long long

每个无符号整数类型的级别都与对应的带符号整数类型相同,所以 unsigned int类型的级别与int类型相同。

否则,如果带符号整数类型的操作数级别低于无符号整数类型的级别,就把带符号整数类型的操作数转换为无符号整数类型。

否则,如果带符号整数类型的值域包含了无符号整数类型所表示的值,就把无符号整数类型转换为带符号整数类型。

否则,两个操作数都转换为带符号整数类型对应的无符号整数类型。

赋值语句中的隐式类型转换

赋值运算右边的表达式只与其左边的变量有不同的类型时,也可以进行隐私类型转换。在一些情况下,这会截短数值,丢失数据。例如,如果赋值操作将float或double类型的值存储在int或long类型的变量中。如下面代码所示

/*赋值语句中的隐式类型转换*/

#include

int main(void)

{

int num2 = 0;

float num3 = 2.5f;

num2 = num3;

printf("%d", num2);

return 0;

}

结果:

3bb0e00e22b77248b0977528e145660c.png

存储在num2中的值是2。这几行代码把num3的值(2.5)赋予int类型的变量num2,就丢失了小数部分.5,只存储了2.注意,在2.5f中使用了指定符f

赋值语句可能丢失信息,因为必须进行隐式类型转换,而编译器通常会为此发出一个警告。但是,代码仍可以编译,所以程序可能会得到不正确的结果。当需要在代码中进行可能导致丢失信息的类型转换时,最好使用显式类型转换。

好了,今天就分享到这里,欢迎大家在评论区和我一起讨论,以后遇到新知识楼主也会及时和大家分享,大家一起学习,一起努力!!

转载请注明出处!转载请注明出处!转载请注明出处!……

  • 6
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值