std::filesystem::recursive_directory_iterator::operator++, std::filesystem::recursive_directory_iterator::increment
来自 cppreference.cn
< cpp | filesystem | 递归目录迭代器
recursive_directory_iterator& operator++(); |
(1) | (始于 C++17) |
recursive_directory_iterator& increment( std::error_code& ec ); |
(2) | (始于 C++17) |
将迭代器前进到下一个条目。 使 *this 的先前值的所有副本无效。
如果当前迭代的目录中没有更多条目,则迭代将在父目录中恢复。 如果父目录没有可以迭代的同级条目,则重复该过程。 如果已到达递归迭代的目录层次结构的父目录(在 depth() == 0 处没有候选条目),则 *this 将设置为结束迭代器。
否则,如果 *this 引用一个目录,则在满足以下条件时迭代到其中
- disable_recursion_pending() 在此递增之前未调用,即 recursion_pending() == true。
- 该目录不是符号链接,或者启用了跟随符号链接,即,以下至少一项为真
- !is_symlink((*this)->symlink_status()).
- (options() & directory_options::follow_directory_symlink) != directory_options::none)
内容 |
[编辑] 参数
ec | - | 用于存储错误状态的错误代码 |
[编辑] 返回值
*this
[编辑] 异常
任何未标记为 noexcept
的重载都可能在内存分配失败时抛出 std::bad_alloc。
1) 在底层操作系统 API 错误时抛出 std::filesystem::filesystem_error,并使用操作系统错误代码作为错误代码参数构造。
[编辑] 示例
本节不完整 原因:没有示例 |
[编辑] 缺陷报告
以下行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。
DR | 应用于 | 已发布行为 | 正确行为 |
---|---|---|---|
LWG 3013 | C++17 | error_code 重载标记为 noexcept 但可以分配内存 | noexcept 已移除 |