如何在 C++ 中把浮点数转换为字符串
Jinku Hu
2023年10月12日
- 在 C++ 中使用宏表达式将浮点数转换为字符串
-
使用
std::to_string()
方法在 C++ 中把浮点数转换为字符串 -
C++ 中使用
std::stringstream
类和str()
方法将浮点数转换为字符串
本文介绍了几种在 C++ 中把浮点数转换为字符串的方法。
在 C++ 中使用宏表达式将浮点数转换为字符串
预处理器宏可以用来将常数浮点数转换为字符串值。需要注意的是,这种解决方案只适用于字面浮点数的转换。下面的代码示例展示了如何使用字符串化宏调用 string
变量构造函数语句。STRING
宏使用 #
操作符将传递的参数转换为字符串常量。
#include <iostream>
#include <string>
using std::cin;
using std::cout;
using std::endl;
using std::string;
#define STRING(num) #num
int main() {
string num_str(STRING(123.456));
num_str.empty() ? cout << "empty\n" : cout << num_str << endl;
return EXIT_SUCCESS;
}
输出:
123.456
如果浮点常量被定义为另一个宏表达式,上述代码应该用一个两级宏代替,以获得正确的结果,如下一段代码所示。
#include <iostream>
#include <string>
using std::cin;
using std::cout;
using std::endl;
using std::string;
#define STRING(num) STR(num)
#define STR(num) #num
#define NUMBER 123.456
int main() {
string num_str(STRING(NUMBER));
num_str.empty() ? cout << "empty\n" : cout << num_str << endl;
return EXIT_SUCCESS;
}
输出:
123.456
使用 std::to_string()
方法在 C++ 中把浮点数转换为字符串
to_string
函数定义在 <string>
头文件中,可以将各种数值类型转换为 string
值。该方法将一个数值作为参数,并返回 std::string
值。需要注意的是,to_string
可能会返回意想不到的结果,因为返回的字符串中的重要数字可能为零,如示例代码所示。
#include <iostream>
#include <string>
using std::cin;
using std::cout;
using std::endl;
using std::string;
int main() {
float n1 = 123.456;
double n2 = 0.456;
double n3 = 1e-40;
string num_str1(std::to_string(n1));
string num_str2(std::to_string(n2));
string num_str3(std::to_string(n3));
num_str1.empty() ? cout << "empty\n" : cout << num_str1 << endl;
num_str2.empty() ? cout << "empty\n" : cout << num_str2 << endl;
num_str3.empty() ? cout << "empty\n" : cout << num_str3 << endl;
return EXIT_SUCCESS;
}
输出:
123.456001
0.456000
0.000000
C++ 中使用 std::stringstream
类和 str()
方法将浮点数转换为字符串
std::stringstream
是一个强大的类,用于对字符串对象进行输入/输出操作。在本方案中,我们利用它将一个浮点变量插入到 stringstream
对象中。然后我们调用 str
内置方法将数值类型处理成 string
对象。请注意,返回的 string
是一个临时对象,所以调用其他方法会产生一个悬空的指针(参见示例中注释的那行)。
#include <iostream>
#include <sstream>
#include <string>
using std::cin;
using std::cout;
using std::endl;
using std::string;
int main() {
float n1 = 123.456;
std::stringstream sstream;
sstream << n1;
string num_str = sstream.str();
// auto *ptr = sstream.str().c_str(); // RESULTS in dangling pointer
num_str.empty() ? cout << "empty\n" : cout << num_str << endl;
return EXIT_SUCCESS;
}
输出:
123.456
作者: Jinku Hu