std::to_string
Von cppreference.com
< cpp | string | 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 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.
|
(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
Führen Sie diesen Code aus
#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
| (C++11) |
konvertiert einen ganzzahligen oder Gleitkommawert in einen wstring(function) |
| (C++11)(C++11) |
konvertiert einen String in eine vorzeichenlose Ganzzahl (function) |
| (C++11)(C++11)(C++11) |
konvertiert einen String in eine vorzeichenbehaftete Ganzzahl (function) |
| (C++11)(C++11)(C++11) |
konvertiert einen String in einen Gleitkommawert (function) |
| (C++17) |
konvertiert einen Ganzzahl- oder Gleitkommawert in eine Zeichensequenz (Funktion) |