关于float和double类型数据的输入输出

来源:互联网 发布:国家数据标准规范 编辑:程序博客网 时间:2024/05/16 15:19

*******************************************************************************

本文为转载博客,转载地址为http://blog.sina.com.cn/s/blog_62c3e3a30100ktlu.html

*******************************************************************************

(1)printf的%f说明符既可以输出float型又可以输出double型。

根据“默认参数提升”规则(在printf这样的函数的可变参数列表中,不论作用域内有没有原型,都适用这一规则)float型会被提升为double型。因此printf()只会看到双精度数。
(2)scanf对于float类型必须用%f,double必须用%lf
对于scanf,情况就完全不同了,它接受指针,这里没有类似的类型提升。(通过指针)向float存储和向double存储大不一样,因此,scanf区别%f和%lf。
(3)事实上,printf中没有定义%lf,但是很多系统可能会接受它。要确保可移植性,就要坚持使用%f。

要想保留小数位数,请使用(比如保留8位小数):
printf("%.8f",a);
0 0