std::filesystem::u8path
Von cppreference.com
< cpp | filesystem | path
| Definiert in Header <filesystem> |
||
| template< class Source > std::filesystem::path u8path( const Source& source ); |
(1) | (seit C++17) (veraltet in C++20) |
| template< class InputIt > std::filesystem::path u8path( InputIt first, InputIt last ); |
(2) | (seit C++17) (veraltet in C++20) |
Konstruiert einen Pfad p aus einer UTF-8-kodierten Sequenz von chars oder char8_ts(seit C++20), entweder als std::string, std::string_view, als nullterminierte Multibyte-Zeichenkette oder als [first, last)-Iteratorenpaar.
- Wenn
path::value_typechar ist und die native Kodierung UTF-8 ist, wird ein Pfad direkt konstruiert, als ob durch path(source) oder path(first, last). Hinweis: Dies ist die typische Situation eines POSIX-Systems, das Unicode verwendet, wie z. B. Linux. - Andernfalls, wenn
path::value_typewchar_t ist und die native Kodierung UTF-16 ist (dies ist die Situation unter Windows), oder wennpath::value_typechar16_t (native Kodierung garantiert UTF-16) oder char32_t (native Kodierung garantiert UTF-32) ist, dann wird die UTF-8-Zeichensequenz zuerst in eine temporäre Zeichenkettetmpvom Typpath::string_typekonvertiert und dann der neue Pfad konstruiert, als ob durch path(tmp). - Andernfalls (für Nicht-UTF-8-Schmalzeichenkodierungen und für Nicht-UTF-16 wchar_t) wird die UTF-8-Zeichensequenz zuerst in eine temporäre UTF-32-kodierte Zeichenkette
tmpvom Typ std::u32string konvertiert und dann der neue Pfad konstruiert, als ob durch path(tmp) (dieser Pfad wird auf einem POSIX-System mit einem nicht-Unicode-Multibyte- oder Single-Byte-kodierten Dateisystem genommen).
Inhalt |
[edit] Parameter
| source | - | eine UTF-8-kodierte std::string, std::string_view, ein Zeiger auf eine nullterminierte Multibyte-Zeichenkette oder ein Eingabeiterator mit `char`-Werttyp, der auf eine nullterminierte Multibyte-Zeichenkette zeigt |
| first, last | - | Paar von LegacyInputIterators, die eine UTF-8-kodierte Zeichensequenz spezifizieren |
| Typanforderungen | ||
-InputIt muss die Anforderungen von LegacyInputIterator erfüllen. | ||
-Der Werttyp von Source oder InputIt muss char oder char8_t(seit C++20) sein. | ||
[edit] Rückgabewert
Der aus der Eingabezeichenkette konstruierte Pfad nach der Konvertierung von UTF-8 in die native Zeichenkodierung des Dateisystems.
[edit] Ausnahmen
Kann std::bad_alloc auslösen, wenn die Speicherzuweisung fehlschlägt.
[edit] Anmerkungen
Auf Systemen, bei denen das native Pfadformat vom generischen Pfadformat abweicht (weder Windows noch POSIX-Systeme sind Beispiele für solche Betriebssysteme), wird, wenn das Argument dieser Funktion das generische Format verwendet, dieses in das native Format konvertiert.
[edit] Beispiel
Führen Sie diesen Code aus
#include <cstdio> #ifdef _MSC_VER #include <fcntl.h> #include <io.h> #else #include <clocale> #include <locale> #endif #include <filesystem> #include <fstream> int main() { #ifdef _MSC_VER _setmode(_fileno(stderr), _O_WTEXT); #else std::setlocale(LC_ALL, ""); std::locale::global(std::locale("")); #endif std::filesystem::path p(u8"要らない.txt"); std::ofstream(p) << "File contents"; // Prior to LWG2676 uses operator string_type() // on MSVC, where string_type is wstring, only // works due to non-standard extension. // Post-LWG2676 uses new fstream constructors // Native string representation can be used with OS-specific APIs #ifdef _MSC_VER if (std::FILE* f = _wfopen(p.c_str(), L"r")) #else if (std::FILE* f = std::fopen(p.c_str(), "r")) #endif { for (int ch; (ch = fgetc(f)) != EOF; std::putchar(ch)) {} std::fclose(f); } std::filesystem::remove(p); }
Mögliche Ausgabe
File contents
[edit] Siehe auch
| (C++17) |
repräsentiert einen Pfad (Klasse) |