std::filesystem::directory_entry:: last_write_time
From cppreference.net
<
cpp
|
filesystem
|
directory entry
|
std::
filesystem
::
file_time_type
last_write_time
(
)
const
;
|
(1) | (desde C++17) |
|
std::
filesystem
::
file_time_type
last_write_time
(
std::
error_code
&
ec
)
const
noexcept
;
|
(2) | (desde C++17) |
Si la hora de la última modificación está almacenada en caché en este
directory_entry
, devuelve el valor almacenado. De lo contrario, devuelve:
1)
std::
filesystem
::
last_write_time
(
path
(
)
)
.
2)
std::
filesystem
::
last_write_time
(
path
(
)
, ec
)
.
Contenidos |
Parámetros
| ec | - | parámetro de salida para reporte de errores en la sobrecarga que no lanza excepciones |
Valor de retorno
La última hora de modificación para el objeto del sistema de archivos referenciado.
Excepciones
Cualquier sobrecarga no marcada como
noexcept
puede lanzar
std::bad_alloc
si la asignación de memoria falla.
1)
Lanza
std::filesystem::filesystem_error
en errores de la API del sistema operativo subyacente, construido con
p
como primer argumento de ruta y el código de error del sistema operativo como argumento de código de error.
2)
Establece un parámetro
std::
error_code
&
al código de error de la API del sistema operativo si una llamada a la API del sistema operativo falla, y ejecuta
ec.
clear
(
)
si no ocurren errores.
Ejemplo
Ejecutar este código
#include <chrono> #include <ctime> #include <filesystem> #include <format> #include <iostream> #include <string> std::string to_string(const std::filesystem::file_time_type& ftime) { #if __cpp_lib_format return std::format("{:%c}", ftime); #else std::time_t cftime = std::chrono::system_clock::to_time_t( std::chrono::file_clock::to_sys(ftime)); std::string str = std::asctime(std::localtime(&cftime)); str.pop_back(); // eliminar el '\n' final puesto por `asctime` return str; #endif } int main() { auto dir = std::filesystem::current_path(); using Entry = std::filesystem::directory_entry; for (Entry const& entry : std::filesystem::directory_iterator(dir)) std::cout << to_string(entry.last_write_time()) << " : " << entry.path().filename() << '\n'; }
Salida posible:
Wed Sep 6 13:37:13.960314156 2023 : "main.cpp" Wed Sep 6 13:37:42.690271828 2023 : "a.out"
Véase también
|
(C++17)
|
obtiene o establece la hora de la última modificación de datos
(función) |