如何在 C++ 中把浮点数转换为字符串

Jinku Hu 2023年10月12日
  1. 在 C++ 中使用宏表达式将浮点数转换为字符串
  2. 使用 std::to_string() 方法在 C++ 中把浮点数转换为字符串
  3. C++ 中使用 std::stringstream 类和 str() 方法将浮点数转换为字符串
如何在 C++ 中把浮点数转换为字符串

本文介绍了几种在 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
Jinku Hu avatar Jinku Hu avatar

DelftStack.com 创始人。Jinku 在机器人和汽车行业工作了8多年。他在自动测试、远程测试及从耐久性测试中创建报告时磨练了自己的编程技能。他拥有电气/电子工程背景,但他也扩展了自己的兴趣到嵌入式电子、嵌入式编程以及前端和后端编程。

LinkedIn Facebook

相关文章 - C++ Float