C++ cout输出固定位数

说一下c++中的输出控制,先交代一下系统环境:

  • 系统:windows 10 x64
  • 编译软件:CodeBlocks

位数控制

    • C语言位数控制
    • C++整数位数控制
    • C++整数进制转换
    • C++小数位数控制

C语言位数控制

在c++编程中经常会遇到浮点数的处理,尤其是对浮点数的位数有要求,在c语言中printf可通过语法快速实现,如下:

    double a=1e-5;// 1 X 10^(-5)
    printf("%.6lf",a);

即可达到以下效果
C++ cout输出固定位数_第1张图片

C++整数位数控制

c++是c语言的升级版,有着比c语言更加多的控制输出条件,主要依赖于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++ cout输出固定位数_第2张图片

C++整数进制转换

同样是使用iomanip头文件,这次使用setbase()函数,别问我为啥只说整数的进制转换,问就是计算机组成原理:10进制有些小数无法被其他进制表示

    cout<<setbase(16)<<21<<endl;//16进制
    cout<<setbase(8)<<21<<endl;//8进制
    cout<<setbase(10)<<0xff<<endl;//10进制

结果如下:

C++ cout输出固定位数_第3张图片
特别说明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;

结果:
C++ cout输出固定位数_第4张图片
当数据较多的时候可以统一处理浮点数小数位数,精简代码。

    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++ cout输出固定位数_第5张图片
这样我们就可以控制数据的输出格式了。

你可能感兴趣的:(技巧,c++)