std::experimental::filesystem:: last_write_time
From cppreference.net
<
cpp
|
experimental
|
fs
|
Definido en el encabezado
<experimental/filesystem>
|
||
|
file_time_type last_write_time
(
const
path
&
p
)
;
file_time_type last_write_time ( const path & p, error_code & ec ) |
(1) | (filesystem TS) |
|
void
last_write_time
(
const
path
&
p, file_time_type new_time
)
;
void last_write_time ( const path & p, file_time_type new_time, error_code & ec ) ; |
(2) | (filesystem TS) |
1)
Devuelve el tiempo de la última modificación de
p
, determinado como si se accediera al miembro
st_mtime
del
stat
de POSIX (los enlaces simbólicos son seguidos).
La sobrecarga que no lanza excepciones devuelve
file_time_type
::
min
(
)
en caso de errores.
2)
Cambia la hora de la última modificación de
p
, como si fuera mediante POSIX
futimens
(los enlaces simbólicos son seguidos).
Contenidos |
Parámetros
| p | - | ruta a examinar o modificar |
| new_time | - | nuevo tiempo de modificación |
| ec | - | parámetro de salida para reporte de errores en la sobrecarga que no lanza excepciones |
Valor de retorno
1)
El tiempo de la última modificación de
p
.
2)
(ninguno)
Excepciones
The overload that does not take an error_code & parameter throws filesystem_error on underlying OS API errors, constructed with p as the first argument and the OS error code as the error code argument. std:: bad_alloc may be thrown if memory allocation fails. The overload taking an error_code & parameter sets it to the OS API error code if an OS API call fails, and executes ec. clear ( ) if no errors occur. This overload has
noexcept
especificación:
noexcept
Notas
No está garantizado que inmediatamente después de establecer la hora de escritura, el valor devuelto por
(1)
sea el mismo que lo que se pasó como argumento a
(2)
porque la hora del sistema de archivos puede ser más granular que
file_time_type
.
Ejemplo
Ejecutar este código
#include <chrono> #include <experimental/filesystem> #include <fstream> #include <iomanip> #include <iostream> namespace fs = std::experimental::filesystem; using namespace std::chrono_literals; int main() { fs::path p = fs::current_path() / "example.bin"; std::ofstream(p.c_str()).put('a'); // crear archivo auto ftime = fs::last_write_time(p); std::time_t cftime = decltype(ftime)::clock::to_time_t(ftime); // asumiendo system_clock std::cout << "File write time is " << std::asctime(std::localtime(&cftime)) << '\n'; fs::last_write_time(p, ftime + 1h); // mover la hora de escritura del archivo 1 hora hacia el futuro ftime = fs::last_write_time(p); // leer nuevamente desde el sistema de archivos cftime = decltype(ftime)::clock::to_time_t(ftime); std::cout << "File write time is " << std::asctime(std::localtime(&cftime)) << '\n'; fs::remove(p); }
Salida posible:
File write time is Tue Mar 31 19:47:04 2015 File write time is Tue Mar 31 20:47:04 2015
Véase también
|
representa valores de tiempo de archivo
(typedef) |