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
结构 的 st_dev
和 st_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) |
确定文件属性 确定文件属性,检查符号链接目标 (函数) |