Namespaces
Variants

std:: to_string

From cppreference.net
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::bad_alloc をスローする可能性があります( std::string コンストラクタから)。

注記

  • 浮動小数点型の場合、 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::to_string std::format に基づいて再定義

#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';
        // 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 (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 に変換する
(関数)
(C++11) (C++11)
文字列を符号なし整数に変換する
(関数)
(C++11) (C++11) (C++11)
文字列を符号付き整数に変換する
(関数)
(C++11) (C++11) (C++11)
文字列を浮動小数点値に変換する
(関数)
(C++17)
整数または浮動小数点値を文字シーケンスに変換する
(関数)