Namensräume
Varianten
Aktionen

std::to_string

Von cppreference.com
< cpp‎ | string‎ | basic string
 
 
 
std::basic_string
 
Definiert in Header <string>
std::string to_string( int value );
(1) (seit C++11)
std::string to_string( long value );
(2) (seit C++11)
std::string to_string( long long value );
(3) (seit C++11)
std::string to_string( unsigned value );
(4) (seit C++11)
std::string to_string( unsigned long value );
(5) (seit C++11)
std::string to_string( unsigned long long value );
(6) (seit C++11)
std::string to_string( float value );
(7) (seit C++11)
std::string to_string( double value );
(8) (seit C++11)
std::string to_string( long double value );
(9) (seit C++11)

Konvertiert einen numerischen Wert in einen std::string.

Sei buf ein interner Puffer der Konvertierungsfunktionen, der groß genug ist, um das Ergebnis der Konvertierung aufzunehmen.

1) Konvertiert eine vorzeichenbehaftete Ganzzahl in einen String, als ob mittels std::sprintf(buf, "%d", value).
2) Konvertiert eine vorzeichenbehaftete Ganzzahl in einen String, als ob mittels std::sprintf(buf, "%ld", value).
3) Konvertiert eine vorzeichenbehaftete Ganzzahl in einen String, als ob mittels std::sprintf(buf, "%lld", value).
4) Konvertiert eine vorzeichenlose Ganzzahl in einen String, als ob mittels std::sprintf(buf, "%u", value).
5) Konvertiert eine vorzeichenlose Ganzzahl in einen String, als ob mittels std::sprintf(buf, "%lu", value).
6) Konvertiert eine vorzeichenlose Ganzzahl in einen String, als ob mittels std::sprintf(buf, "%llu", value).
7,8) Konvertiert eine Gleitkommazahl in einen String, als ob mittels std::sprintf(buf, "%f", value).
9) Konvertiert eine Gleitkommazahl in einen String, als ob mittels std::sprintf(buf, "%Lf", value).
(bis C++26)
1-9) Konvertiert einen numerischen Wert in einen String, als ob mittels std::format("{}", value).
(seit C++26)

Inhalt

[bearbeiten] Parameter

value - ein zu konvertierender numerischer Wert

[bearbeiten] Rückgabewert

Ein String, der den konvertierten Wert enthält.

[bearbeiten] Ausnahmen

Kann std::bad_alloc vom std::string-Konstruktor auslösen.

[bearbeiten] Hinweise

  • Bei Gleitkommatypen kann `std::to_string` unerwartete Ergebnisse liefern, da die Anzahl der signifikanten Stellen im zurückgegebenen String null sein kann, siehe Beispiel.
  • Der Rückgabewert kann sich erheblich von dem unterscheiden, was `std::cout` standardmäßig ausgibt, siehe Beispiel.
  • std::to_string verwendet die aktuelle C-Locale für Formatierungszwecke. Daher können gleichzeitige Aufrufe von std::to_string von mehreren Threads zu einer teilweisen Serialisierung der Aufrufe führen.
    • Die Ergebnisse der Überladungen für Ganzzahltypen sind nicht von der aktuellen C-Locale abhängig, und daher vermeiden Implementierungen im Allgemeinen den Zugriff auf die aktuelle C-Locale in diesen Überladungen, sowohl aus Korrektheits- als auch aus Leistungsgründen. Eine solche Vermeidung wird jedoch nicht vom Standard garantiert.
(bis C++26)

C++17 bietet std::to_chars als eine leistungsfähigere, locale-unabhängige Alternative.

Feature-Test-Makro Wert Std Feature
__cpp_lib_to_string 202306L (C++26) Neudefinition von std::to_string basierend auf std::format

[bearbeiten] Beispiel

#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";
    }
}

Mögliche Ausgabe

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

[bearbeiten] Siehe auch

konvertiert einen ganzzahligen oder Gleitkommawert in einen wstring
(function) [edit]
(C++11)(C++11)
konvertiert einen String in eine vorzeichenlose Ganzzahl
(function) [edit]
(C++11)(C++11)(C++11)
konvertiert einen String in eine vorzeichenbehaftete Ganzzahl
(function) [edit]
(C++11)(C++11)(C++11)
konvertiert einen String in einen Gleitkommawert
(function) [edit]
(C++17)
konvertiert einen Ganzzahl- oder Gleitkommawert in eine Zeichensequenz
(Funktion) [bearbeiten]