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"
[編輯] 參閱
檢查當前目錄是否停用遞迴 (公共成員函式) | |
前進到下一個條目 (公共成員函式) |