微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

double的输入格式符是什么

使用scanf语句时,double的输入格式符是“%lf”,不能使用“%f”;使用printf语句时,可以使用“%f”,printf中没有定义%lf,但是很多系统会接受。因此建议使用double类型时,用“%lf”输入避免出错。

本教程操作环境:windows7系统、C++17版、Dell G3电脑。

(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。

建议大家使用double类型时,用%lf输入,%f输出避免出错。

推荐教程:《C#

原文地址:https://www.jb51.cc/csharp/1192463.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐