std::filesystem:: space
|
Definiert im Header
<filesystem>
|
||
|
std::
filesystem
::
space_info
space
(
const
std::
filesystem
::
path
&
p
)
;
|
(1) | (seit C++17) |
|
std::
filesystem
::
space_info
space
(
const
std::
filesystem
::
path
&
p,
std:: error_code & ec ) noexcept ; |
(2) | (seit C++17) |
Bestimmt die Informationen über das Dateisystem, auf dem der Pfadname
p
sich befindet, wie durch POSIX
statvfs
.
Füllt ein Objekt vom Typ
filesystem::space_info
und gibt es zurück, gesetzt aus den Mitgliedern der POSIX
struct
statvfs
wie folgt:
-
space_info.capacitywird gesetzt als ob durch f_blocks * f_frsize . -
space_info.freewird gesetzt auf f_bfree * f_frsize . -
space_info.availablewird gesetzt auf f_bavail * f_frsize . - Jedes Element, das nicht bestimmt werden konnte, wird gesetzt auf static_cast < std:: uintmax_t > ( - 1 ) .
Die nicht-werfende Überladung setzt bei Fehler alle Member auf static_cast < std:: uintmax_t > ( - 1 ) .
Inhaltsverzeichnis |
Parameter
| p | - | zu untersuchender Pfad |
| ec | - | Out-Parameter für Fehlerberichterstattung in der nicht-werfenden Überladung |
Rückgabewert
Die Dateisysteminformationen (ein
filesystem::space_info
Objekt).
Ausnahmen
Jede Überladung, die nicht als
noexcept
gekennzeichnet ist, kann
std::bad_alloc
auslösen, wenn die Speicherallokation fehlschlägt.
Hinweise
space_info.available
kann weniger sein als
space_info.free
.
Beispiel
#include <cstdint> #include <filesystem> #include <iostream> #include <locale> std::uintmax_t disk_usage_percent(const std::filesystem::space_info& si, bool is_privileged = false) noexcept { if (constexpr std::uintmax_t X(-1); si.capacity == 0 || si.free == 0 || si.available == 0 || si.capacity == X || si.free == X || si.available == X ) return 100; std::uintmax_t unused_space = si.free, capacity = si.capacity; if (!is_privileged) { const std::uintmax_t privileged_only_space = si.free - si.available; unused_space -= privileged_only_space; capacity -= privileged_only_space; } const std::uintmax_t used_space{capacity - unused_space}; return 100 * used_space / capacity; } void print_disk_space_info(auto const& dirs, int width = 14) { (std::cout << std::left).imbue(std::locale("en_US.UTF-8")); for (const auto s : {"Capacity", "Free", "Available", "Use%", "Dir"}) std::cout << "│ " << std::setw(width) << s << ' '; for (std::cout << '\n'; auto const& dir : dirs) { std::error_code ec; const std::filesystem::space_info si = std::filesystem::space(dir, ec); for (auto x : {si.capacity, si.free, si.available, disk_usage_percent(si)}) std::cout << "│ " << std::setw(width) << static_cast<std::intmax_t>(x) << ' '; std::cout << "│ " << dir << '\n'; } } int main() { const auto dirs = {"/dev/null", "/tmp", "/home", "/proc", "/null"}; print_disk_space_info(dirs); }
Mögliche Ausgabe:
│ Capacity │ Free │ Available │ Use% │ Dir │ 84,417,331,200 │ 42,732,986,368 │ 40,156,028,928 │ 50 │ /dev/null │ 84,417,331,200 │ 42,732,986,368 │ 40,156,028,928 │ 50 │ /tmp │ -1 │ -1 │ -1 │ 100 │ /home │ 0 │ 0 │ 0 │ 100 │ /proc │ -1 │ -1 │ -1 │ 100 │ /null
Siehe auch
|
(C++17)
|
Informationen über freien und verfügbaren Speicherplatz im Dateisystem
(Klasse) |