命名空间
变体
操作

std::filesystem::path::compare

来自 cppreference.cn
< cpp‎ | filesystem‎ | path
 
 
 
 
int compare( const path& p ) const noexcept;
(1) (since C++17)
int compare( const string_type& str ) const;
int compare( std::basic_string_view<value_type> str ) const;
(2) (since C++17)
int compare( const value_type* s ) const;
(3) (since C++17)

比较路径和另一个路径的词汇表示。

1) 如果 root_name().native().compare(p.root_name().native()) 非零,则返回该值。
否则,如果 has_root_directory() != p.has_root_directory(), 如果 has_root_directory()false,则返回值小于零,否则返回值大于零。
否则,如果路径的相对部分 (relative_path()) 分别在字典序上小于、等于或大于 p 的相对部分 (p.relative_path()),则返回值小于、等于或大于 0。比较是逐元素进行的,如同从 begin() 迭代到 end() 并比较每个元素的 native() 的结果一样。
2) 等效于 compare(path(str))
3) 等效于 compare(path(s))

内容

[编辑] 参数

p - 要比较的路径
str - 表示要比较路径的字符串或字符串视图
s - 表示要比较路径的空终止字符串

[编辑] 返回值

如果路径在字典序上小于给定路径,则返回值小于 0

如果路径在字典序上等于给定路径,则返回值等于 0

如果路径在字典序上大于给定路径,则返回值大于 0

[编辑] 异常

2,3) 可能抛出实现定义的异常。

[编辑] 注释

对于双向比较,二元运算符 可能更适合。

[编辑] 示例

#include <filesystem>
#include <iostream>
#include <string_view>
namespace fs = std::filesystem;
 
void demo(fs::path p1, fs::path p2, std::string_view msg)
{
    std::cout << p1;
    const int rc = p1.compare(p2); 
    if (rc < 0)
        std::cout << " < ";
    else if (rc > 0)
        std::cout << " > ";
    else
        std::cout << " == ";
    std::cout << p2 << " \t: " << msg << '\n';
}
 
int main()
{
    demo("/a/b/", "/a/b/", "simple");
    demo("/a/b/", "/a/b/c", "simple");
    demo("/a/b/../b", "/a/b", "no canonical conversion");
    demo("/a/b", "/a/b/.", "no canonical conversion");
    demo("/a/b/", "a/c", "absolute paths order after relative ones");
}

输出

"/a/b/" == "/a/b/"      : simple
"/a/b/" < "/a/b/c"	: simple
"/a/b/../b" > "/a/b"	: no canonical conversion
"/a/b" < "/a/b/."	: no canonical conversion
"/a/b/" > "a/c"	        : absolute paths order after relative ones

[编辑] 缺陷报告

以下行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。

DR 应用于 已发布行为 正确行为
LWG 2936 C++17 直接比较所有路径元素 根名称和根目录单独处理

[编辑] 参见

(C++17)(C++17)(until C++20)(C++17)(until C++20)(C++17)(until C++20)(C++17)(until C++20)(C++17)(until C++20)(C++20)
按字典顺序比较两个路径
(函数) [编辑]