初始问题,有一个很简单的例题。计算正弦值
#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对于各种格式说明符可以接受的参数类型。
