平时的C++编程中,经常会进行浮点数据小数位的控制,那么怎么样用printf和cout输出控制小数位数呢?
1.printf输出我们可以这样实现:
printf("%.2f",a); //保留两位小数
2.cout输出我们可以这样实现:
我们要实现这个需求,都是调用setprecision()函数来实现这个目的,实现过程如下:
#include <iomanip>
cout.setf(ios::fixed);
cout << "a=" << setprecision(2) << a <<endl; //保留两位小数
3.有时候我们可能在数据处理过程中,保留小数并不是在打印阶段,而是在数据传递过程中需要进行小数位保留,例如我们希望浮点类型数据3.1415926,保留两位小数后变为字符串"3.14"。代码如下:
#include <iomanip>
#include <iostream>
#include <sstream>
int main()
{
float temp=3.1415926;
std::stringstream buff;
buff.precision(2);//覆盖默认精度,保留小数位
buff.setf(std::ios::fixed);
buff << temp;
std::string a;
a = buff.str();
std::cout << a << std::endl;
}
最终浮点类型temp变量变成字符串"3.14"。
3.14
上面这个处理,是在我一个项目中需要将浮点型温度数据打印在图片上,我使用的opencv库中的putText函数打印时,就需要保留小数后打印,直接打印putText源码并没有操作保留小数的参数,所以我就不得不先将数据进行处理后再打印。
还想学习更多干货,就赶快加入我的公众号吧!一起加油加油!