名前空間
変種
操作

std::to_string

From cppreference.com
< cpp‎ | string‎ | basic string
 
 
 
std::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`がデフォルトで出力するものと大きく異なる場合があります。例を参照してください。
  • `std::to_string`は書式設定のために現在のCロケールに依存しているため、複数のスレッドからの`std::to_string`への同時呼び出しは、呼び出しの部分的なシリアル化を引き起こす可能性があります。
    • 整数型のオーバーロードの結果は現在のCロケールに依存しないため、実装は通常、正確性とパフォーマンスの両方のために、これらのオーバーロードで現在のCロケールへのアクセスを回避します。ただし、このような回避は標準によって保証されていません。
(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

[編集] 関連項目

整数値または浮動小数点値を wstring に変換する
(function) [編集]
(C++11)(C++11)
文字列を符号なし整数に変換する
(function) [編集]
(C++11)(C++11)(C++11)
文字列を符号付き整数に変換する
(function) [編集]
(C++11)(C++11)(C++11)
文字列を浮動小数点値に変換する
(function) [編集]
(C++17)
整数値または浮動小数点数値を文字シーケンスに変換する
(関数) [編集]
English 日本語 中文(简体) 中文(繁體)