C++果然是非常微妙的语言,%f和%lf对于printf()和scanf()的效果是不同的。
事实上,对于printf(),无论是%f还是%lf,效果都是一样的。
因为,遇到float,printf()会将float类型自动提升到double,所以不会有什么问题。
而且严格地讲,printf()并没有对于%lf的定义,虽然很多编译器会接受,所以最好使用%f。
而对于scanf(),由于接受的是指针,并没有类型提升的说法,所以对于double就应该用%lf,float就是%f。
本文探讨了C++中%f与%lf在printf()和scanf()函数中的不同表现。对于printf(),两者效果相同;而scanf()则严格区分%f用于float,%lf用于double。
C++果然是非常微妙的语言,%f和%lf对于printf()和scanf()的效果是不同的。
事实上,对于printf(),无论是%f还是%lf,效果都是一样的。
因为,遇到float,printf()会将float类型自动提升到double,所以不会有什么问题。
而且严格地讲,printf()并没有对于%lf的定义,虽然很多编译器会接受,所以最好使用%f。
而对于scanf(),由于接受的是指针,并没有类型提升的说法,所以对于double就应该用%lf,float就是%f。
1万+
7972
7680

被折叠的 条评论
为什么被折叠?