名前空間
変種
操作

std::filesystem::begin(recursive_directory_iterator), std::filesystem::end(recursive_directory_iterator)

提供: cppreference.com
 
 
 
 
recursive_directory_iterator begin( recursive_directory_iterator iter ) noexcept;
(1) (C++17以上)
recursive_directory_iterator end( const recursive_directory_iterator& ) noexcept;
(2) (C++17以上)
1) iter を変更せずに返します。
2) デフォルト構築された recursive_directory_iterator を返します。 これは終端イテレータとして機能します。 引数は無視されます。

これらの非メンバ関数は、 recursive_directory_iterator を範囲ベースの for ループで使用できるようにします。

目次

[編集] 引数

iter - recursive_directory_iterator

[編集] 戻り値

1) 無変更の iter
2) 終端イテレータ (デフォルト構築された recursive_directory_iterator)。

[編集]

#include <fstream>
#include <iostream>
#include <filesystem>
namespace fs = std::filesystem;
 
int main()
{
    fs::create_directories("sandbox/a/b");
    std::ofstream("sandbox/file1.txt");
    fs::create_symlink("a", "sandbox/syma");
    for(auto& p: fs::recursive_directory_iterator("sandbox"))
        std::cout << p << '\n';
    fs::remove_all("sandbox");
}

出力例:

"sandbox/a"
"sandbox/a/b"
"sandbox/file1.txt"
"sandbox/syma"

[編集] 関連項目

範囲ベースの for ループサポート
(関数) [edit]