C++玄学问题 关于printf输出double类型显示0.000000的原因

运行环境 win10 codeblocks 17.12

一、 C++ double类型用 %lf 格式输出

【输出错误】:-0.000000

在这里插入图片描述

二、 C++ double类型用 %f 格式输出【输出正确】

在这里插入图片描述

三、 C语言 double类型用 %lf 或 %f 格式输出 【均输出正确】

在这里插入图片描述
这让我感到十分玄学,为什么第一种输出就不对了呢,double类型为什么不能写%lf输出?
(编译器选用 dev c++ 或者 vs code 在C++中按 %lf 输出double类型均可正确输出,而codeblocks 17.12选用C++会输出0.000000)

原因

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

答:printf的%f说明符的确既可以输出float型又可以输出double型。 根据"默认参数提升"规则(在printf这样的函数的可变参数列表中 ,不论作用域内有没有原型,都适用这一规则)float型会被提升为double型。因此printf()只会看到双精度数。对于scanf,情况就完全不同了,它接受指针,这里没有类似的类型提升。(通过指针)向float存储和向double存储大不一样,因此,scanf区别%f和%lf。

严格地讲,%lf在printf下是未定义的,但是很多系统(或者其他编译器)可能会接受它。要确保可移植性,就要坚持使用%f。总之,以后按 %f 输出double类型吧!

参考文章:https://blog.csdn.net/sinat_14958547/article/details/37877405?depth_1-utm_source=distribute.pc_relevant.none-task&utm_source=distribute.pc_relevant.none-task

发布了100 篇原创文章 · 获赞 131 · 访问量 5万+

猜你喜欢

转载自blog.csdn.net/ljw_study_in_CSDN/article/details/104671993