C++ cout输出固定位数

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

说一下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;

效果如下:
在这里插入图片描述
这样我们就可以控制数据的输出格式了。

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值