std::experimental::filesystem::resize_file
Von cppreference.com
< cpp | experimental | fs
| Definiert im Header <experimental/filesystem> |
||
| void resize_file( const path& p, std::uintmax_t new_size ); void resize_file( const path& p, std::uintmax_t new_size, error_code& ec ); |
(Dateisystem-TS) | |
Ändert die Größe der regulären Datei mit dem Namen 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, als wäre er mit Nullen gefüllt.
Inhalt |
[bearbeiten] Parameter
| p | - | Pfad zum Ändern der Größe |
| 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
Die Überladung, die keinen Parameter error_code& nimmt, wirft filesystem_error bei zugrunde liegenden OS-API-Fehlern, konstruiert mit p als erstem Argument und dem OS-Fehlercode als Fehlercode-Argument. std::bad_alloc kann geworfen werden, wenn die Speicherzuweisung fehlschlägt. Die Überladung, die einen Parameter error_code& nimmt, setzt diesen auf den OS-API-Fehlercode, wenn ein OS-API-Aufruf fehlschlägt, und führt ec.clear() aus, wenn keine Fehler auftreten. Diese Überladung hatnoexcept-Spezifikation:
noexcept
[bearbeiten] Hinweise
Auf Systemen, die Sparse Files unterstützen, erhöht die Vergrößerung der Dateigröße nicht den von ihr auf dem Dateisystem belegten Speicherplatz: Die Speicherplatzreservierung findet nur statt, wenn Nicht-Null-Bytes in die Datei geschrieben werden.
[bearbeiten] Beispiel
Demonstriert die Auswirkung des Erstellens eines Sparse Files auf den freien Speicherplatz.
Führen Sie diesen Code aus
#include <experimental/filesystem> #include <fstream> #include <iostream> namespace fs = std::experimental::filesystem; int main() { fs::path p = fs::temp_directory_path() / "example.bin"; std::ofstream(p).put('a'); std::cout << "File size: " << fs::file_size(p) << '\n' << "Free space: " << fs::space(p).free << '\n'; fs::resize_file(p, 64*1024); // resize to 64 KB std::cout << "File size: " << fs::file_size(p) << '\n' << "Free space: " << fs::space(p).free << '\n'; fs::remove(p); }
Mögliche Ausgabe
File size: 1 Free space: 31805444096 File size: 65536 Free space: 31805444096
[bearbeiten] Siehe auch
| gibt die Größe einer Datei zurück (Funktion) | |
| ermittelt den verfügbaren freien Speicherplatz auf dem Dateisystem (Funktion) |