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) 抛出 std::filesystem::filesystem_error,构造时以 p1 为第一路径实参,以 p2 为第二路径实参,并以OS 错误码为错误码实参。

若 OS API 调用失败,则 @2@ 设置 std::error_code& 形参

为 OS API 错误码,而未发生错误时则执行 ec.clear()

注解

若两个路径解析到的候选实体位于同设备的同一位置,则认为它们解析到同一文件系统实体。对于 POSIX,这表明其如同以 POSIX stat() 获得的 POSIX stat 结构st_devst_ino 成员相等。

特别是,同一文件或目录的所有硬链接等价,而同一文件系统上的符号链接与其目标等价。

示例

#include <cstdint>
#include <filesystem>
#include <iostream>
namespace fs = std::filesystem;
 
int main()
{
    // 硬链接等价
    fs::path p1 = ".";
    fs::path p2 = fs::current_path();
    if(fs::equivalent(p1, p2))
        std::cout << p1 << " is equivalent to " << p2 << '\n';
 
    // 符号链接等价
    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++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20)
以字典序比较两个路径
(函数)
(C++17)(C++17)
确定文件属性
确定文件属性,检查符号链接目标
(函数)