std::filesystem::recursive_directory_iterator::disable_recursion_pending
来自 cppreference.com
void disable_recursion_pending(); |
(自 C++17 起) | |
禁用对当前引用的子目录(如果有)的递归。
调用修改了迭代器上的挂起递归标志,使得下次调用increment时,即使迭代器当前引用的是尚未访问的子目录,迭代器也会在当前目录内前进。
可以使用recursion_pending()查询挂起递归标志的状态,该状态在本次调用后为false。在increment之后,它被重置回true,并且它的初始值也是true。
如果*this是末尾迭代器,则行为未定义。
内容 |
[编辑] 参数
(无)
[编辑] 返回值
(无)
[编辑] 异常
可能抛出实现定义的异常。
[编辑] 示例
运行此代码
#include <cstdlib> #include <filesystem> #include <fstream> #include <iostream> #include <string> namespace fs = std::filesystem; int main() { fs::current_path(fs::temp_directory_path()); fs::create_directories("sandbox/a/b/c"); fs::create_directories("sandbox/a/b/d/e"); std::ofstream("sandbox/a/b/file1.txt"); fs::create_symlink("a", "sandbox/syma"); std::system("tree sandbox"); for (auto i = fs::recursive_directory_iterator("sandbox"); i != fs::recursive_directory_iterator(); ++i) { std::cout << std::string(i.depth() * 2, ' ') << *i; if (fs::is_symlink(i->symlink_status())) std::cout << " -> " << fs::read_symlink(*i); std::cout << '\n'; // do not descend into "b" if (i->path().filename() == "b") i.disable_recursion_pending(); } fs::remove_all("sandbox"); }
可能的输出
sandbox ├── a │ └── b │ ├── c │ ├── d │ │ └── e │ └── file1.txt └── syma -> a "sandbox/a" "sandbox/a/b" "sandbox/syma" -> "a"
[编辑] 另请参阅
检查当前目录的递归是否已禁用 (公共成员函数) | |
前进到下一个条目 (公共成员函数) |