std::filesystem::filesystem_error::what
Von cppreference.com
< cpp | filesystem | filesystem error
| const char* what() const noexcept override; |
(seit C++17) | |
Gibt eine erklärende Byte-Zeichenkette zurück. Diese erklärende Zeichenkette enthält die beim Konstruktionszeitpunkt übergebene erklärende Zeichenkette. Implementierungen sind angehalten, die Pfadnamen von path1() und path2() im nativen Format und die Zeichenkette von std::system_error::what() innerhalb der zurückgegebenen Zeichenkette einzuschließen.
[bearbeiten] Parameter
(keine)
[bearbeiten] Rückgabewert
Eine erklärende C-Style-Byte-Zeichenkette, die die beim Konstruktionszeitpunkt übergebene erklärende Zeichenkette enthält.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <cstdio> #include <filesystem> #include <iostream> #include <string_view> namespace fs = std::filesystem; void explain(std::string_view note, fs::filesystem_error const& ex) { std::cout << note << " exception:\n" << "what(): " << ex.what() << '\n' << "path1(): " << ex.path1() << ", path2(): " << ex.path2() << "\n\n"; } int main() { try { std::filesystem::rename("/dev", "/null"); } catch(fs::filesystem_error const& ex) { explain("fs::rename()", ex); } for (auto const path : {"/bool", "/bin/cat", "/bin/mouse"}) try { std::filesystem::create_directory(path); } catch(fs::filesystem_error const& ex) { explain("fs::create_directory()", ex); } }
Mögliche Ausgabe
fs::rename() exception: what(): filesystem error: cannot rename: Permission denied [/dev] [/null] path1(): "/dev", path2(): "/null" fs::create_directory() exception: what(): filesystem error: cannot create directory: Permission denied [/bool] path1(): "/bool", path2(): "" fs::create_directory() exception: what(): filesystem error: cannot create directory: File exists [/bin/cat] path1(): "/bin/cat", path2(): "" fs::create_directory() exception: what(): filesystem error: cannot create directory: Read-only file system [/bin/mouse] path1(): "/bin/mouse", path2(): ""