命名空间
变体
操作

std::filesystem::path::lexically_normal, std::filesystem::path::lexically_relative, std::filesystem::path::lexically_proximate

来自 cppreference.cn
< cpp‎ | filesystem‎ | path
 
 
 
 
path lexically_normal() const;
(1) (C++17 起)
path lexically_relative( const path& base ) const;
(2) (C++17 起)
path lexically_proximate( const path& base ) const;
(3) (C++17 起)
1) 返回以其通用格式转换到规范形式*this
2) 返回相对于 base*this
  • 首先,若 root_name() != base.root_name()true,或 is_absolute() != base.is_absolute()true,或 (!has_root_directory() && base.has_root_directory())true,或 relative_path()base.relative_path() 中的任何文件名能被解释为根名 (root-name),则返回默认构造的 path。
  • 否则,首先确定 *thisbase 的首个不匹配元素,如同以 auto [a, b] = mismatch(begin(), end(), base.begin(), base.end()),然后
  • a == end()b == base.end(),则返回 path(".")
  • 否则,定义 N[b, base.end()) 中既非亦非点点的非空文件名元素数量,减去点点文件名元素数量,若 N < 0,则返回默认构造的 path,
  • 否则,若 N = 0a == end() || a->empty(),则返回 path(".")
  • 否则返回由以下部分组成的对象
  • 一个默认构造的 path(),后随
  • N 次应用 operator/=(path("..")),后随
  • 对于半开范围 [aend()) 中的每个元素应用一次 operator/=
3)lexically_relative(base) 的值不是空路径,则返回它。否则返回 *this

目录

[编辑] 参数

(无)

[编辑] 返回值

1) 路径的规范形式。
2) 路径的相对形式。
3) 路径的邻近形式。

[编辑] 异常

可能抛出实现定义的异常。

[编辑] 注意

这些转换是纯粹词法上的。它们不检查路径是否存在,不跟随符号链接,且完全不访问文件系统。对于 lexically_relativelexically_proximate 的跟随符号链接的对应版本,见 relativeproximate

在 Windows 上,返回的 path 含有反斜杠(首选分隔符)。

在 POSIX 上,相对路径中没有文件名能被接受为根名 (root-name)

[编辑] 示例

#include <cassert>
#include <filesystem>
#include <iostream>
namespace fs = std::filesystem;
 
int main()
{
    assert(fs::path("a/./b/..").lexically_normal() == "a/");
    assert(fs::path("a/.///b/../").lexically_normal() == "a/");
    assert(fs::path("/a/d").lexically_relative("/a/b/c") == "../../d");
    assert(fs::path("/a/b/c").lexically_relative("/a/d") == "../b/c");
    assert(fs::path("a/b/c").lexically_relative("a") == "b/c");
    assert(fs::path("a/b/c").lexically_relative("a/b/c/x/y") == "../..");
    assert(fs::path("a/b/c").lexically_relative("a/b/c") == ".");
    assert(fs::path("a/b").lexically_relative("c/d") == "../../a/b");
    assert(fs::path("a/b").lexically_relative("/a/b") == "");
    assert(fs::path("a/b").lexically_proximate("/a/b") == "a/b");
}

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
LWG 3070 C++17 亦可为根名的文件名可能导致意外结果 被作为错误情况处理
LWG 3096 C++17 末尾的 "/" 与 "/." 处理不正确 已更正

[编辑] 参阅

组成一个相对路径
(函数) [编辑]