名稱空間
變體
操作

std::filesystem::equivalent

來自 cppreference.com
 
 
 
定義於標頭檔案 <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,

                 std::error_code& ec ) noexcept;
(2) (C++17 起)

檢查路徑 p1p2 是否解析到相同的檔案系統實體。

如果 p1p2 不存在,則會報告錯誤。

在錯誤發生時,不丟擲異常的過載函式返回 false

目錄

[編輯] 引數

p1, p2 - 要檢查等效性的路徑
ec - 非丟擲過載中用於錯誤報告的出參

[編輯] 返回值

如果 p1p2 指向相同的檔案或目錄且它們的檔案狀態相同,則返回 true。否則返回 false

[編輯] 異常

任何未標記為 noexcept 的過載都可能在記憶體分配失敗時丟擲 std::bad_alloc

1) 當底層作業系統 API 發生錯誤時,丟擲 std::filesystem::filesystem_error,其中 p1 作為第一個路徑引數,p2 作為第二個路徑引數,作業系統錯誤碼作為錯誤碼引數。
2) 如果作業系統 API 呼叫失敗,則將 std::error_code& 引數設定為作業系統 API 錯誤碼;如果沒有發生錯誤,則執行 ec.clear()

[編輯] 注意

如果兩個路徑解析到的候選實體位於同一裝置上的同一位置,則認為它們解析到相同的檔案系統實體。對於 POSIX 系統,這意味著透過 POSIX stat() 獲取的其 POSIX stat 結構體st_devst_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)
確定檔案屬性
確定檔案屬性,檢查符號連結目標
(函式) [編輯]