std::filesystem::path::compare
来自cppreference.com
| |
(1) | (C++17 起) |
| |
(2) | (C++17 起) |
| |
(3) | (C++17 起) |
比较 path 与另一 path 的词法表示。
1) 若
root_name().native().compare(p.root_name().native()) 非零,则返回该值。 否则若
has_root_directory() != p.has_root_directory(),则若 has_root_directory() 为 false 则返回小于零的值,否则返回大于零的值。 否则,若
path 的相对部分 (relative_path()) 分别按字典序小于、等于或大于 p 的相对部分 (p.relative_path()),则分别返回小于、等于或大于 0 的值。逐元素进行比较,如同从begin() 到 end() 迭代 path,并比较各元素的 native()。2) 等价于
compare(path(str))。3) 等价于
compare(path(s))。参数
| p | - | 要比较的 path
|
| str | - | 表示要比较的表示路径的字符串或字符串视图 |
| s | - | 表示要比较的路径的空终止字符串 |
返回值
若 path 按字典序小于给定 path 则为小于 0 的值。
若 path 按字典序等于给定 path 则为等于 0 的值。
若 path 按字典序大于给定 path 则为大于 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/", "简单");
demo("/a/b/", "/a/b/c", "简单");
demo("/a/b/../b", "/a/b", "无规范转换");
demo("/a/b", "/a/b/.", "无规范转换");
demo("/a/b/", "a/c", "绝对路径按序在相对路径之后");
}
输出:
"/a/b/" == "/a/b/" : 简单
"/a/b/" < "/a/b/c" : 简单
"/a/b/../b" > "/a/b" : 无规范转换
"/a/b" < "/a/b/." : 无规范转换
"/a/b/" > "a/c" : 绝对路径按序在相对路径之后
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
| 缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
|---|---|---|---|
| LWG 2936 | C++17 | 直接比较所有路径元素 | 分开处理根名与根目录 |
参阅
(C++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20) |
以字典序比较两个路径 (函数) |