如何避免科学记数法而显示完整数字?
How to avoid scientific notation and show full number instead?
我在其中一个库中有以下代码,它导致一些数字以科学记数法的形式显示。
T value = 0;
template<typename U> void process(U& buf, DataOption holder) const {
if (holder == DataOption::TYPES) {
switch (type_) {
case teck::PROC_INT:
buf << "{\"int\":" << value << "}";
break;
case teck::PROC_LONG:
buf << "{\"long\":" << value << "}";
break;
case teck::PROC_FLOAT:
buf << "{\"float\":" << value << "}";
break;
case teck::PROC_DOUBLE:
buf << "{\"double\":" << value << "}";
break;
default:
buf << "{\"" << type_ << "\":" << value << "}";
}
}
}
对于上述一些不同的情况,"value" 以科学记数法表示。我怎样才能避免显示科学记数法,而是显示完整的数字?我做了一些研究,我可以使用 "std::fixed" 但我应该在哪里使用它?
这是一个流装饰器:
buf << std::fixed << double_value;
查看更多:std::fixed
std::fixed
在同一流中工作,因此如果您使用的是无状态流,这将不起作用
case teck::PROC_DOUBLE:
buf << std::fixed;
buf << "{\"double\":" << value << "}";
应该是这样的
case teck::PROC_DOUBLE:
buf << "{\"double\":" << std::fixed << value << "}";
所以你的函数可以像这样简化为了更好的可读性
template<typename U> void process(U& buf, DataOption holder) const
{
if (holder == DataOption::TYPES)
{
buf << "{\"";
switch (type_)
{
case teck::PROC_INT: buf << "int"; break;
case teck::PROC_LONG: buf << "long"; break;
case teck::PROC_FLOAT: buf << "float"; break;
case teck::PROC_DOUBLE: buf << "double"; break;
default: buf << type_;
}
buf << "\":" << std::fixed << value << "}";
}
}
我在其中一个库中有以下代码,它导致一些数字以科学记数法的形式显示。
T value = 0;
template<typename U> void process(U& buf, DataOption holder) const {
if (holder == DataOption::TYPES) {
switch (type_) {
case teck::PROC_INT:
buf << "{\"int\":" << value << "}";
break;
case teck::PROC_LONG:
buf << "{\"long\":" << value << "}";
break;
case teck::PROC_FLOAT:
buf << "{\"float\":" << value << "}";
break;
case teck::PROC_DOUBLE:
buf << "{\"double\":" << value << "}";
break;
default:
buf << "{\"" << type_ << "\":" << value << "}";
}
}
}
对于上述一些不同的情况,"value" 以科学记数法表示。我怎样才能避免显示科学记数法,而是显示完整的数字?我做了一些研究,我可以使用 "std::fixed" 但我应该在哪里使用它?
这是一个流装饰器:
buf << std::fixed << double_value;
查看更多:std::fixed
std::fixed
在同一流中工作,因此如果您使用的是无状态流,这将不起作用
case teck::PROC_DOUBLE:
buf << std::fixed;
buf << "{\"double\":" << value << "}";
应该是这样的
case teck::PROC_DOUBLE:
buf << "{\"double\":" << std::fixed << value << "}";
所以你的函数可以像这样简化为了更好的可读性
template<typename U> void process(U& buf, DataOption holder) const
{
if (holder == DataOption::TYPES)
{
buf << "{\"";
switch (type_)
{
case teck::PROC_INT: buf << "int"; break;
case teck::PROC_LONG: buf << "long"; break;
case teck::PROC_FLOAT: buf << "float"; break;
case teck::PROC_DOUBLE: buf << "double"; break;
default: buf << type_;
}
buf << "\":" << std::fixed << value << "}";
}
}