说一下c++中的输出控制,先交代一下系统环境:
- 系统:windows 10 x64
- 编译软件:CodeBlocks
C语言位数控制
在c++编程中经常会遇到浮点数的处理,尤其是对浮点数的位数有要求,在c语言中printf可通过语法快速实现,如下:
double a=1e-5;// 1 X 10^(-5)
printf("%.6lf",a);
即可达到以下效果

C++整数位数控制
c++是c语言的升级版,有着比c语言更加多的控制输出条件,主要依赖于iomanip头文件中的函数,主要使用<iomanip>中的setw()和setfill()函数
代码如下:
double a=1e-5;
int b=2;
//设置输出5位宽度 默认右对齐
cout<<setw(5)<<b<<endl;
//设置输出5位宽度 不足位数用0补
cout<<setfill('0')<<setw(5)<<b<<endl;
效果如下:

C++整数进制转换
同样是使用iomanip头文件,这次使用setbase()函数,别问我为啥只说整数的进制转换,问就是计算机组成原理:10进制有些小数无法被其他进制表示
cout<<setbase(16)<<21<<endl;//16进制
cout<<setbase(8)<<21<<endl;//8进制
cout<<setbase(10)<<0xff<<endl;//10进制
结果如下:

特别说明setbase函数只能以8,10,16为参数,即只能转化成8进制,10进制,16进制的数。输入其他参数时函数失效。
C++小数位数控制
同样使用iomanip头文件,使用setprecision()函数
double a=1e-5;
cout.setf(ios::fixed,ios::floatfield);//不用科学计数法表示浮点数
cout<<setprecision(6)<<a<<endl;
结果:

当数据较多的时候可以统一处理浮点数小数位数,精简代码。
double a=1e-5;
cout.setf(ios::fixed,ios::floatfield);//不用科学计数法表示浮点数
cout.precision(7);
cout<<a<<endl;
cout<<a<<endl;
cout<<1.4e-2<<endl;
cout<<a<<endl;
cout<<a<<endl;
效果如下:

这样我们就可以控制数据的输出格式了。
本文介绍了在C++中如何控制输出的位数和进制,包括C语言的位数控制、C++的整数位数控制、整数进制转换和小数位数控制。通过使用<iomanip>库中的setw(), setfill(), setbase()和setprecision()等函数,可以精确地调整整数和浮点数的显示格式。"
87006132,5808113,CentOS7下Rsync+sersync实时数据同步实践,"['数据实时同步', '数据备份', 'CentOS', 'Rsync工具', 'sersync工具']





