命名空间
变体
操作

std::filesystem::path::concat, std::filesystem::path::operator+=

来自 cppreference.com
< cpp‎ | filesystem‎ | path
 
 
 
 
path& operator+=( const path& p );
(1) (自 C++17 起)
path& operator+=( const string_type& str );
path& operator+=( std::basic_string_view<value_type> str );
(2) (自 C++17 起)
path& operator+=( const value_type* ptr );
(3) (自 C++17 起)
path& operator+=( value_type x );
(4) (自 C++17 起)
template< class CharT >
path& operator+=( CharT x );
(5) (自 C++17 起)
template< class Source >
path& operator+=( const Source& source );
(6) (自 C++17 起)
template< class Source >
path& concat( const Source& source );
(7) (自 C++17 起)
template< class InputIt >
path& concat( InputIt first, InputIt last );
(8) (自 C++17 起)

连接当前路径和参数

1-3,6,7) 在本机格式下将 path(p).native() 附加到存储在 *this 中的路径名。这直接操作 native() 的值,并且可能无法在操作系统之间移植。
4,5)return *this += std::basic_string_view(&x, 1); 相同。
8)return *this += path(first, last); 相同。

(6)(7) 仅在 Sourcepath 不属于同一类型时参与重载解析,并且以下任一条件成立:

内容

[编辑] 参数

p - 要附加的路径
str - 要附加的字符串或字符串视图
ptr - 指向要附加的以 null 结尾的字符串的开头
x - 要附加的单个字符
source - std::basic_string, std::basic_string_view, 以 null 结尾的多字符字符串,或指向表示路径名的以 null 结尾的多字符序列的输入迭代器(以可移植格式或本机格式)
first, last - 指定表示路径名的多字符序列的一对 LegacyInputIterators
类型要求
-
InputIt 必须满足 LegacyInputIterator 的要求。
-
InputIt 的值类型必须是编码字符类型之一 (char, wchar_t, char16_tchar32_t).
-
CharT 必须是编码字符类型之一 (char, wchar_t, char16_tchar32_t).

[编辑] 返回值

*this

[编辑] 异常

可能抛出 std::bad_alloc 如果内存分配失败。

[编辑] 注释

不像 append()operator/=,不会引入额外的目录分隔符。

[编辑] 示例

#include <filesystem>
#include <iostream>
#include <string>
 
int main()
{
    std::filesystem::path p1; // an empty path
    p1 += "var"; // does not insert a separator
    std::cout << R"("" + "var" --> )" << p1 << '\n';
    p1 += "lib"; // does not insert a separator
    std::cout << R"("var" + "lib" --> )" << p1 << '\n';
    auto str = std::string{"1234567"};
    p1.concat(std::begin(str) + 3, std::end(str) - 1);
    std::cout << "p1.concat --> " << p1 << '\n';
}

输出

"" + "var" --> "var"
"var" + "lib" --> "varlib"
p1.concat --> "varlib456"

[编辑] 缺陷报告

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

DR 应用于 已发布的行为 正确的行为
LWG 3055 C++17 连接单个字符的规范是不合法的 已修改为合法
LWG 3244 C++17 缺少 `Source` 不能为 `path` 的约束 已添加

[编辑] 另请参阅

使用目录分隔符将元素追加到路径
(公有成员函数) [编辑]
(C++17)
使用目录分隔符连接两个路径
(函数) [编辑]