std::filesystem::recursive_directory_iterator::operator++, std::filesystem::recursive_directory_iterator::increment

来自cppreference.com
 
 
 
 
recursive_directory_iterator& operator++();
(C++17 起)
recursive_directory_iterator& increment( std::error_code& ec );
(C++17 起)

前进迭代器到下个条目。非法化所有 *this 的先前值的副本。

若当前被迭代目录没有剩下更多条目,则回撤迭代到亲目录。若亲目录亦无能迭代的兄弟条目,则重复此过程。若抵达已被递归迭代的目录层级的亲目录(在 depth() == 0) 无更多可选择条目),则设置 *this 为尾迭代器。

否则,若 *this 代表目录,则若满足下列条件则迭代进入它:

  • disable_recursion_pending() 在此次自增前未被调用,即 recursion_pending() == true
  • 目录不是符号链接或启用跟随符号链接,即至少下列之一为 true :
    • !is_symlink((*this)->symlink_status())
    • (options() & directory_options::follow_directory_symlink) != directory_options::none)

参数

ec - 要存储错误状态的错误码

返回值

*this

异常

不接受 std::error_code& 参数的重载在底层 OS API 错误时抛出 filesystem_error ,以作为错误码参数的 OS 错误码构造。若 OS API 调用失败,则接受 std::error_code& 参数的重载设置该参数为 OS API 错误码,而若不出现错误则执行 ec.clear() 。若内存分配失败,则任何不标记为 noexcept 的重载可能抛出 std::bad_alloc

缺陷报告

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

DR 应用于 出版时的行为 正确行为
LWG 3013 C++17 error_code 重载被标记为 noexcept 但能分配内存 移除 noexcept