std::to_string
From 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 に変換します。
|
変換関数の内部にあるバッファ`buf`は、変換結果を格納するのに十分な大きさを持つものとします。 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 " (post C++26)"; } #else constexpr auto revision() { return " (pre 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'; // Before C++26, the output of std::to_string matches std::printf. std::printf("printf:\t\t%f\n", f); // As of C++26, the output of std::to_string matches std::format. std::cout << std::format("format:\t\t{}\n", f); std::cout << "std::cout:\t" << f << "\n\n"; } }
実行結果の例
to_string: 1.234568 (pre C++26) printf: 1.234568 format: 1.23456789555555 std::cout: 1.23457 to_string: 23.430000 (pre C++26) printf: 23.430000 format: 23.43 std::cout: 23.43 to_string: 0.000000 (pre C++26) printf: 0.000000 format: 1e-09 std::cout: 1e-09 to_string: 10000000000000000303786028427003666890752.000000 (pre C++26) printf: 10000000000000000303786028427003666890752.000000 format: 1e+40 std::cout: 1e+40 to_string: 0.000000 (pre C++26) printf: 0.000000 format: 1e-40 std::cout: 1e-40 to_string: 123456789.000000 (pre C++26) printf: 123456789.000000 format: 123456789 std::cout: 1.23457e+08
[編集] 関連項目
| (C++11) |
整数値または浮動小数点値を wstring に変換する(function) |
| (C++11)(C++11) |
文字列を符号なし整数に変換する (function) |
| (C++11)(C++11)(C++11) |
文字列を符号付き整数に変換する (function) |
| (C++11)(C++11)(C++11) |
文字列を浮動小数点値に変換する (function) |
| (C++17) |
整数値または浮動小数点数値を文字シーケンスに変換する (関数) |