std::filesystem::equivalent
< cpp | filesystem
定义于头文件 <filesystem>
|
||
bool equivalent( const std::filesystem::path& p1, const std::filesystem::path& p2 ); |
(1) | (C++17 起) |
检查路径 p1
与 p2
是否指代同一文件或目录,并拥有如 status 所检验的相同文件状态(跟随符号链接)。
若 p1
与 p2
均不存在,或均存在但都不是文件、目录或符号链接(如 is_other 所检验),则报告错误。
不抛出重载在错误时返回 false
。
参数
p1, p2 | - | 要检测等价性的路径 |
ec | - | 不抛出重载中报告错误的输出参数 |
返回值
若 p1
与 p2
指代同一文件或目录且其文件状态相同则为 true 。否则为 false 。
异常
不接受 std::error_code& 参数的重载在底层 OS API 错误时抛出 filesystem_error ,以第一 path 参数 p1
,第二 path 参数 p2
和作为错误码参数的 OS 错误码构造。若 OS API 调用失败,则接受 std::error_code& 参数的重载设置该参数为 OS API 错误码,而若不出现错误则执行 ec.clear() 。若内存分配失败,则任何不标记为 noexcept
的重载可能抛出 std::bad_alloc 。
注意
若二个路径的如同以 POSIX stat 获得的 POSIX stat 结构体的 st_dev
与 st_ino
相等,则认为它们解析为同一文件系统实体。(这表示文件位于同一设备、同一位置)
通常,所有同一文件的目录或硬链接等价,而同一文件系统上的符号链接与其目标等价。
示例
运行此代码
#include <iostream> #include <cstdint> #include <filesystem> 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'; // 符号链接等价性 fs::path p3 = "/lib/libc.so.6"; fs::path p4 = p3.parent_path() / fs::read_symlink(p3); if(fs::equivalent(p3, p4)) std::cout << p3 << " is equivalent to " << p4 << '\n'; }
可能的输出:
"." is equivalent to "/var/tmp/test" "/lib/libc.so.6" is equivalent to "/lib/libc-2.12.so"
参阅
(C++17)(C++17) |
确定文件属性 确定文件属性,检查符号链接目标 (函数) |