std::filesystem::resize_file
| Definiert in Header <filesystem> |
||
| void resize_file( const std::filesystem::path& p, std::uintmax_t new_size ); |
(1) | (seit C++17) |
| void resize_file( const std::filesystem::path& p, std::uintmax_t new_size, |
(2) | (seit C++17) |
Ändert die Größe der regulären Datei namens p, als ob durch POSIX truncate: Wenn die Dateigröße zuvor größer als new_size war, wird der Rest der Datei verworfen. Wenn die Datei zuvor kleiner als new_size war, wird die Dateigröße erhöht und der neue Bereich erscheint so, als wäre er mit Nullen gefüllt.
Inhalt |
[bearbeiten] Parameter
| p | - | Pfad zur Größenänderung |
| new_size | - | Größe, die die Datei nun haben wird |
| ec | - | Ausgabeparameter für die Fehlerberichterstattung in der nicht auslösenden Überladung |
[bearbeiten] Rückgabewert
(keine)
[bearbeiten] Ausnahmen
Jede Überladung, die nicht als noexcept markiert ist, kann std::bad_alloc auslösen, wenn die Speicherzuweisung fehlschlägt.
[bearbeiten] Hinweise
Auf Systemen, die Sparse Files unterstützen, erhöht die Vergrößerung der Dateigröße nicht den Speicherplatz, den sie auf dem Dateisystem belegt: Die Speicherplatzzuweisung erfolgt nur dann, wenn Nicht-Null-Bytes in die Datei geschrieben werden.
[bearbeiten] Beispiel
Demonstriert die Auswirkung, die das Erstellen eines Sparse Files auf den freien Speicherplatz hat.
#include <filesystem> #include <fstream> #include <iostream> #include <locale> int main() { auto p = std::filesystem::temp_directory_path() / "example.bin"; std::ofstream{p}.put('a'); std::cout.imbue(std::locale{"en_US.UTF8"}); std::cout << "File size: " << std::filesystem::file_size(p) << '\n' << "Free space: " << std::filesystem::space(p).free << '\n'; std::filesystem::resize_file(p, 64*1024); // resize to 64 KB std::cout << "File size: " << std::filesystem::file_size(p) << '\n' << "Free space: " << std::filesystem::space(p).free << '\n'; std::filesystem::remove(p); }
Mögliche Ausgabe
File size: 1 Free space: 42,954,108,928 File size: 65,536 Free space: 42,954,108,928
[bearbeiten] Siehe auch
| (C++17) |
gibt die Größe einer Datei zurück (Funktion) |
| (C++17) |
ermittelt den verfügbaren freien Speicherplatz auf dem Dateisystem (Funktion) |