std::experimental::filesystem::recursive_directory_iterator::depth
來自 cppreference.com
< cpp | experimental | fs | recursive_directory_iterator
int depth() const; |
(檔案系統 TS) | |
返回從起始目錄到當前迭代目錄的目錄數量,即目錄層次結構的當前深度。
起始目錄的深度為 0,其子目錄的深度為 1,以此類推。
如果 *this 是末尾迭代器,則行為未定義。
目錄 |
[編輯] 引數
(無)
[編輯] 返回值
目錄層次結構的當前深度。
[編輯] 異常
不丟擲任何異常。
[編輯] 示例
此示例使用迭代深度來計算目錄樹列印輸出的縮排。
執行此程式碼
#include <experimental/filesystem> #include <fstream> #include <iostream> #include <string> namespace fs = std::experimental::filesystem; int main() { 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"); for (auto i = fs::recursive_directory_iterator("sandbox"); i != fs::recursive_directory_iterator(); ++i) { std::cout << std::string(i.depth(), ' ') << *i; if (fs::is_symlink(i->symlink_status())) std::cout << " -> " << fs::read_symlink(*i); std::cout << '\n'; } fs::remove_all("sandbox"); }
輸出
"sandbox/a" "sandbox/a/b" "sandbox/a/b/c" "sandbox/a/b/d" "sandbox/a/b/d/e" "sandbox/a/b/file1.txt" "sandbox/syma" -> "a"