Prevent scientific notation in ostream when using << with double

只愿长相守 提交于 2019-12-17 02:37:37

问题


I need to prevent my double to print in scientific notation in my file,

when I do this

outfile << X;

回答1:


To set formatting of floating variables you can use a combination of setprecision(n), showpoint and fixed. In order to use parameterized stream manipulators like setprecision(n) you will have to include the iomanip library:

#include <iomanip>

setprecision(n): will constrain the floating-output to n places, and once you set it, it is set until you explicitly unset it for the remainder of the stream output.

fixed: will enforce that all floating-point numbers are output the same way. So if your precision is set to 4 places, 6.2, and 6.20 will both be output as:

6.2000
6.2000

showpoint: will force the decimal portions of a floating-point variable to be displayed, even if it is not explicitly set. For instance, 4 will be output as:

4.0

Using them all together:

outfile << fixed << showpoint;
outfile << setprecision(4);
outfile << x;



回答2:


All the above answers were useful, but none directly answer the question.

outfile.setf(ios_base::fixed);
outfile << x;

I found the answer in @moogs link: http://www.cplusplus.com/reference/iostream/ios_base/fmtflags/

Here's a demo program: http://ideone.com/FMxRp1




回答3:


Here's an example of usage http://cplus.about.com/od/learning1/ss/clessontwo_4.htm

as per your question use

  std::cout << std::fixed << a << std::endl;



回答4:


you can use format flags   

http://en.cppreference.com/w/cpp/io/ios_base/fmtflags



来源:https://stackoverflow.com/questions/2335657/prevent-scientific-notation-in-ostream-when-using-with-double

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!