C语言学习日记 1 数据溢出

涉及链接图片以及任何转载内容,如有冒犯,请及时联系我删除 

遗留问题 为什么float 类型的数据 为什么不是一个精确值而是一个近似值

#include
void main()
{
    float PI = 3.14159;
    int s,r = 5;
    s = r * r*PI;
    printf("s=%d\n", s);
}

输出结果 s=75

PI 是实型 s,r  为整型 运行的时候先将 s,r转换为double,进行计算,因为s申明为整型,所以程序会将计算结果取整变成整型,取整会导致精度下降

#include
void main()
{
    float s, PI = 3.14159;
    int r = 5;
    s = r * r*PI;
    printf("s=%d\n", s);
}

输出结果:s=1073741824

修改后,将s 也申明为实型 ,计算结果就不会取取整,精度自然不会下降

但是s的值变成了1073741824,显然与真确的数值相差巨大

C语言学习日记 1 数据溢出_第1张图片

可以看到这里的PI=3.14159 实际上是一个近似值(3.14158999999999883) 所以数据溢出了

解决:将输出的 printf(“s=%d\n”,s); 改为printf("%e"\n,s);运行结果为7.853975e+01

%d 整型输出 

%e以指数形式输出实数

当然这里也可以用%f 运行结果为78.535749

你可能感兴趣的:(C语言学习,c语言)