命名空间
变体
操作

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 结构st_devst_ino 成员(获取方式类似于 POSIX stat())相等。

特别是,同一个文件或目录的所有硬链接都是等效的,并且同一个文件系统上的符号链接及其目标是等效的。

[编辑] 示例

#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++ 标准。

DR 应用于 已发布的行为 正确行为
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)
确定文件属性
确定文件属性,检查符号链接目标
(函数) [编辑]