【发布时间】:2021-05-31 15:46:37
【问题描述】:
在 C++17 中,迭代某个目录 dir 中的项目变得很容易:
for ( auto& dirEntry: std::filesystem::directory_iterator(dir) )
{
if ( !dirEntry.is_regular_file() ) continue;
...
不幸的是,这种方式可能会引发异常,我想在我的程序中避免这种情况。
不抛出异常的迭代也是可以的:
std::error_code ec;
const std::filesystem::directory_iterator dirEnd;
for ( auto it = std::filesystem::directory_iterator( dir, ec ); !ec && it != dirEnd; it.increment( ec ) )
{
if ( !it->is_regular_file( ec ) ) continue;
...
但它在 C++ 中更加冗长。例如,我不能使用基于范围的 for。这个更大的代码大小对我来说真的很重要,因为我有很多地方需要迭代。 有没有办法简化代码迭代目录项,同时又能避免异常?
【问题讨论】:
-
当然。像上面那样编写一个例程,然后从任何地方调用它。
-
您如何期望基于范围的 for 循环指示错误?您无权访问迭代器,也不能抛出异常。不过,您也许可以编写一个包装类,将目录条目视为结束迭代器(并可能提供错误信息)。
-
注意两个版本都可能抛出
std::bad_alloc。 (/me 不喜欢文件系统接口)。 -
我唯一的建议是
using别名...?using DirIt = std::filesystem::directory_iterator;你可能已经想到了,但我只是以防万一。
标签: c++ c++17 c++-standard-library std-filesystem