std::filesystem::equivalent

定义于头文件 <filesystem>
bool equivalent( const std::filesystem::path& p1,

                 const std::filesystem::path& p2 );
bool equivalent( const std::filesystem::path& p1,
                 const std::filesystem::path& p2,

                 std::error_code& ec );
(1) (C++17 起)

检查路径 p1p2 是否指代同一文件或目录,并拥有如 status 所检验的相同文件状态(跟随符号链接)。

p1p2 均不存在,或均存在但都不是文件、目录或符号链接(如 is_other 所检验),则报告错误。

不抛出重载在错误时返回 false

目录

参数

p1, p2 - 要检测等价性的路径
ec - 不抛出重载中报告错误的输出参数

返回值

p1p2 指代同一文件或目录且其文件状态相同则为 true 。否则为 false

异常

不接受 std::error_code& 参数的重载在底层 OS API 错误时抛出 filesystem_error ,以第一参数 p1,第二参数 p2 和作为错误码参数的 OS 错误码构造。若内存分配失败则可能抛出 std::bad_alloc 。若 OS API 调用失败,则接受 std::error_code& 参数的重载设置该参数为 OS API 错误码,而若不出现错误则执行 ec.clear()

注意

若二个路径的如同以 POSIX stat 获得的 POSIX stat 结构体st_devst_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)
确定文件属性
确定文件属性,检查符号链接对象
(函数)

版本历史

  • (当前 | 先前) 2017年4月30日 (日) 22:02Fruderica讨论 | 贡献. . (2,397字节) (+2,397). . (以“{{cpp/filesystem/title|equivalent}} {{cpp/filesystem/navbar}} {{dcl begin}} {{dcl header | filesystem}} {{dcl | num=1 | since=c++17 | 1= bool equivalent( const std::...”为内容创建页面)