std::to_string
来自cppreference.com
< cpp | string | basic string
在标头 <string> 定义
|
||
std::string to_string( int value ); |
(1) | (C++11 起) |
std::string to_string( long value ); |
(2) | (C++11 起) |
std::string to_string( long long value ); |
(3) | (C++11 起) |
std::string to_string( unsigned value ); |
(4) | (C++11 起) |
std::string to_string( unsigned long value ); |
(5) | (C++11 起) |
std::string to_string( unsigned long long value ); |
(6) | (C++11 起) |
std::string to_string( float value ); |
(7) | (C++11 起) |
std::string to_string( double value ); |
(8) | (C++11 起) |
std::string to_string( long double value ); |
(9) | (C++11 起) |
将数值转换为 std::string。
令 1) 把有符号十进制整数转换为字符串,如同 std::sprintf(buf, "%d", value)。
2) 把有符号十进制整数转换为字符串,如同 std::sprintf(buf, "%ld", value)。
3) 把有符号十进制整数转换为字符串,如同 std::sprintf(buf, "%lld", value)。
4) 把无符号十进制整数转换为字符串,如同 std::sprintf(buf, "%u", value)。
5) 把无符号十进制整数转换为字符串,如同 std::sprintf(buf, "%lu", value)。
6) 把无符号十进制整数转换为字符串,如同 std::sprintf(buf, "%llu", value)。
7,8) 把浮点值转换为字符串,如同 std::sprintf(buf, "%f", value)。
9) 把浮点值转换为字符串,如同 std::sprintf(buf, "%Lf", value)。
|
(C++26 前) |
1-9) 如同 std::format("{}", value) 转换数值为字符串。
|
(C++26 起) |
参数
value | - | 需要转换的数值 |
返回值
包含转换后数值的字符串
异常
可能从 std::string 的构造函数抛出 std::bad_alloc。
注解
- 对于浮点类型,
std::to_string
可能产生不期待的结果,因为返回的字符串中的有效位数能为零,见示例。 - 返回值可以明显地有别于
std::cout
所默认打印的结果,见示例。
|
(C++26 前) |
C++17 提供高性能、不依赖本地环境的替用品 std::to_chars。
功能特性测试宏 | 值 | 标准 | 功能特性 |
---|---|---|---|
__cpp_lib_to_string |
202306L | (C++26) | 用 std::format 重新定义 std::to_string
|
示例
运行此代码
#include <cstdio> #include <format> #include <initializer_list> #include <iostream> #include <string> #if __cpp_lib_to_string >= 202306L constexpr auto revision() { return " (C++26 后)"; } #else constexpr auto revision() { return " (C++26 前)"; } #endif int main() { for (const double f : {1.23456789555555, 23.43, 1e-9, 1e40, 1e-40, 123456789.0}) { std::cout << "to_string:\t" << std::to_string(f) << revision() << '\n'; // C++26 之前,std::to_string 的输出与 std::printf 匹配。 std::printf("printf:\t\t%f\n", f); // C++26 起,std::to_string 的输出与 std::format 匹配。 std::cout << std::format("format:\t\t{}\n", f); std::cout << "std::cout:\t" << f << "\n\n"; } }
可能的输出:
to_string: 1.234568 (C++26 前) printf: 1.234568 format: 1.23456789555555 std::cout: 1.23457 to_string: 23.430000 (C++26 前) printf: 23.430000 format: 23.43 std::cout: 23.43 to_string: 0.000000 (C++26 前) printf: 0.000000 format: 1e-09 std::cout: 1e-09 to_string: 10000000000000000303786028427003666890752.000000 (C++26 前) printf: 10000000000000000303786028427003666890752.000000 format: 1e+40 std::cout: 1e+40 to_string: 0.000000 (C++26 前) printf: 0.000000 format: 1e-40 std::cout: 1e-40 to_string: 123456789.000000 (C++26 前) printf: 123456789.000000 format: 123456789 std::cout: 1.23457e+08
参阅
(C++11) |
转换整数或浮点值为 wstring (函数) |
(C++11)(C++11) |
转换字符串为无符号整数 (函数) |
(C++11)(C++11)(C++11) |
转换字符串为有符号整数 (函数) |
(C++11)(C++11)(C++11) |
转换字符串为浮点值 (函数) |
(C++17) |
转换整数或浮点值为字符序列 (函数) |