std::filesystem::equivalent
來自 cppreference.com
< cpp | filesystem
定義於標頭檔案 <filesystem> |
||
bool equivalent( const std::filesystem::path& p1, const std::filesystem::path& p2 ); |
(1) | (C++17 起) |
bool equivalent( const std::filesystem::path& p1, const std::filesystem::path& p2, |
(2) | (C++17 起) |
檢查路徑 p1 和 p2 是否解析到相同的檔案系統實體。
如果 p1 或 p2 不存在,則會報告錯誤。
在錯誤發生時,不丟擲異常的過載函式返回 false。
目錄 |
[編輯] 引數
p1, p2 | - | 要檢查等效性的路徑 |
ec | - | 非丟擲過載中用於錯誤報告的出參 |
[編輯] 返回值
如果 p1 和 p2 指向相同的檔案或目錄且它們的檔案狀態相同,則返回 true。否則返回 false。
[編輯] 異常
任何未標記為 noexcept
的過載都可能在記憶體分配失敗時丟擲 std::bad_alloc。
1) 當底層作業系統 API 發生錯誤時,丟擲 std::filesystem::filesystem_error,其中 p1 作為第一個路徑引數,p2 作為第二個路徑引數,作業系統錯誤碼作為錯誤碼引數。
[編輯] 注意
如果兩個路徑解析到的候選實體位於同一裝置上的同一位置,則認為它們解析到相同的檔案系統實體。對於 POSIX 系統,這意味著透過 POSIX stat()
獲取的其 POSIX stat
結構體的 st_dev
和 st_ino
成員是相等的。
特別地,同一檔案或目錄的所有硬連結都是等效的,同一檔案系統上的符號連結及其目標也是等效的。
[編輯] 示例
執行此程式碼
#include <cstdint> #include <filesystem> #include <iostream> namespace fs = std::filesystem; int main() { // hard link equivalency fs::path p1 = "."; fs::path p2 = fs::current_path(); if (fs::equivalent(p1, p2)) std::cout << p1 << " is equivalent to " << p2 << '\n'; // symlink equivalency for (const fs::path lib : {"/lib/libc.so.6", "/lib/x86_64-linux-gnu/libc.so.6"}) { try { p2 = lib.parent_path() / fs::read_symlink(lib); } catch (std::filesystem::filesystem_error const& ex) { std::cout << ex.what() << '\n'; continue; } if (fs::equivalent(lib, p2)) std::cout << lib << " is equivalent to " << p2 << '\n'; } }
可能的輸出
"." is equivalent to "/var/tmp/test" filesystem error: read_symlink: No such file or directory [/lib/libc.so.6] "/lib/x86_64-linux-gnu/libc.so.6" is equivalent to "/lib/x86_64-linux-gnu/libc-2.23.so"
[編輯] 缺陷報告
下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
LWG 2937 | C++17 | 錯誤條件指定不正確 | 已更正 |
[編輯] 另請參閱
按字典順序比較兩個路徑的詞法表示 ( std::filesystem::path 的公共成員函式) | |
(C++17)(C++17)(直到 C++20)(C++17)(直到 C++20)(C++17)(直到 C++20)(C++17)(直到 C++20)(C++17)(直到 C++20)(C++20) |
按字典順序比較兩個路徑 (函式) |
(C++17)(C++17) |
確定檔案屬性 確定檔案屬性,檢查符號連結目標 (函式) |