设置scientific标志导致浮点数字值以科学记数法显示(似乎是以十六进制表示)。当设置fixed时,浮点值以通常记数法显示。缺省时,当设置fixed时,显示六位十进制位。当这些标志都没有设置时,编译程序选择一种适当的方式。setprecsion(n)是格式控制符。由于cout自身的问题,所以输出精度可能不会和原始数据完全吻合。如何做到输出数据尽可能吻合原始数据,我还没找到很好的办法。
#include<iostream>
#include <iomanip>
using namespace std;
int main(){
double a=123.456789012345;
cout<<a<<endl;
cout<<fixed<<a<<endl;
cout<<fixed<<setprecision(9)<<a<<endl;
cout<<a<<setprecision(0)<<endl;
cout<<a<<endl;
cout<<setiosflags(ios::scientific)<<a<<endl;
cout<<setiosflags(ios::scientific)<<fixed<<a<<endl;
cout<<setiosflags(ios::scientific)<<setprecision(4)<<a<<endl;
cout<<setiosflags(ios::scientific)<<fixed<<setprecision(4)<<a<<endl;
system("pause");
}
123.457
123.456789
123.456789012
123.456789012
123
0x2p+6
123
0x1.edd4p+6
123.4568
请按任意键继续. . .