std::filesystem:: last_write_time
|
ヘッダーで定義
<filesystem>
|
||
|
std::
filesystem
::
file_time_type
last_write_time
(
const
std::
filesystem
::
path
&
p
)
;
|
(1) | (C++17以降) |
|
std::
filesystem
::
file_time_type
last_write_time
(
const
std::
filesystem
::
path
&
p,
std:: error_code & ec ) noexcept ; |
(2) | (C++17以降) |
|
void
last_write_time
(
const
std::
filesystem
::
path
&
p,
std:: filesystem :: file_time_type new_time ) ; |
(3) | (C++17以降) |
|
void
last_write_time
(
const
std::
filesystem
::
path
&
p,
std::
filesystem
::
file_time_type
new_time,
|
(4) | (C++17以降) |
stat
のメンバ
st_mtime
にアクセスする場合と同様に決定されます(シンボリックリンクは追従されます)。
例外を投げないオーバーロードは、エラー時に
file_time_type
::
min
(
)
を返します。
futimens
を使用した場合と同様に(シンボリックリンクは追従されます)。
目次 |
パラメータ
| p | - | 調査または変更するパス |
| new_time | - | 新しい変更時刻 |
| ec | - | 例外を投げないオーバーロードにおけるエラー報告用出力パラメータ |
戻り値
例外
noexcept
でマークされていないオーバーロードは、
メモリ確保に失敗した場合に
std::bad_alloc
をスローする可能性があります。
注記
書き込み時間を設定した直後に、 (1,2) によって返される値が (3,4) の引数として渡された値と同じであることは保証されません。これは、ファイルシステムの時間が filesystem::file_time_type よりも細かい粒度を持つ可能性があるためです。
例
#include <chrono> #include <filesystem> #include <format> #include <fstream> #include <iostream> using namespace std::chrono_literals; int main() { auto p = std::filesystem::temp_directory_path() / "example.bin"; std::ofstream{p.c_str()}.put('a'); // ファイル作成 std::filesystem::file_time_type ftime = std::filesystem::last_write_time(p); std::cout << std::format("File write time is {}\n", ftime); // ファイルの最終更新時刻を1時間未来に設定 std::filesystem::last_write_time(p, ftime + 1h); // ファイルシステムから再読み込み ftime = std::filesystem::last_write_time(p); std::cout << std::format("File write time is {}\n", ftime); std::filesystem::remove(p); }
出力例:
File write time is 2023-09-04 19:33:24.702639224 File write time is 2023-09-04 20:33:24.702639224
関連項目
|
(C++17)
|
ファイルの時間値を表現する
(typedef) |
|
ディレクトリエントリが参照するファイルの最終データ更新時刻を取得する
(
std::filesystem::directory_entry
の公開メンバ関数)
|