c语言的double类型printf %lf 显示0.00000问题

1,029 阅读1分钟

初始问题,有一个很简单的例题。计算正弦值

#include<stdio.h>
#include<math.h>
int main()
{
    double x,s;
    printf("input number:\n");
    scanf("%lf",&x);
    s = sin(x);
    printf("sine of %lf is %lf\n",x,s);
    return 0;
}

编译运行后:

很明显,输出结果与预期不符合。 找了很多相同计算正弦值的代码,进行对比,几经波折,最后发现,问题出在lf与f上

int main()
{
    double answer,x;
    printf("input number:\n");
    scanf("%lf",&x);
    answer=sin(x);
    printf("sin(%f) = %f\n", x,answer);//输出语句使用f即可
    return 0;
}

借鉴资料:book.51cto.com/art/200901/…

问:有人告诉我不能在printf中使用%lf。为什么printf()用%f输出double型,而scanf却用%lf呢?

答:printf的%f说明符的确既可以输出float型又可以输出double型。 根据"默认参数提升"规则(在printf这样的函数的可变参数列表中 ,不论作用域内有没有原型,都适用这一规则)float型会被提升为double型。因此printf()只会看到双精度数。参见问题15.2。

对于scanf,情况就完全不同了,它接受指针,这里没有类似的类型提升。(通过指针)向float存储和向double存储大不一样,因此,scanf区别%f和%lf。

下表列出了printf和scanf对于各种格式说明符可以接受的参数类型。