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) 抛出 std::filesystem::filesystem_error,构造时以 p1 为第一路径实参,以 p2 为第二路径实参,并以OS 错误码为错误码实参。
若 OS API 调用失败,则 @2@ 设置 std::error_code& 形参
为 OS API 错误码,而未发生错误时则执行 ec.clear()。注解
若两个路径解析到的候选实体位于同设备的同一位置,则认为它们解析到同一文件系统实体。对于 POSIX,这表明其如同以 POSIX stat()
获得的 POSIX stat
结构的 st_dev
与 st_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) |
确定文件属性 确定文件属性,检查符号链接目标 (函数) |