Qt中利用QDirIterator获取目录下的所有文件
Qt 遍历文件夹的三种方式
-----------------------------------------
====================================
Qt 遍历文件夹的三种方式
github dome https://github.com/yingzai5/loadfiledome
今天的心态被搞崩溃了,在多年的编程经验里。普遍的经验认为在遍历文件夹这件事情上,肯定是队列优于递归的。
但在Qt 由于有一些库函数,我发现使用递归的速度尽然比队列还快,而且队列的遍历还特别的慢,估计是我写的队列遍历那个地方又问题,请大神指导一下,这是为什么呢?我一个qt初学者真心想把这个问题搞清楚。因为之前在公司电脑测试的时候,发现队列确实别递归快,但是回家用自己的笔记本测试的时候发现,在文件特别多的时候,队列的代码耗时特别长!!
递归
//递归实现文件的遍历
void TfileThread::getFiles(const QString& path)
{
if (this->isInterruptionRequested())
return;QDir dir;
dir.setPath(path);QFileInfoList infolist = dir.entryInfoList(QDir::AllDirs | QDir::Files | QDir::NoDotAndDotDot);
foreach(const QFileInfo & info, infolist)
{
if (this->isInterruptionRequested())
break;if (info.isDir())
getFiles(info.absoluteFilePath());
else
m_filelist << info.absoluteFilePath();
}
}
队列
//队列实现文件的遍历
void TfileThread::queuegetFiles(const QString& path){
QDir dir(m_path);
QFileInfoList infolist = dir.entryInfoList(QDir::AllDirs | QDir::Files | QDir::NoDotAndDotDot);
QFileInfoList infolist2;
QFileInfo info;
for(int i=0; i < infolist.count(); i++)
{
if (this->isInterruptionRequested())
return;
info =infolist.at(i);
if(info.isDir())
{
dir.setPath(info.absoluteFilePath());
infolist2 =dir.entryInfoList(QDir::AllDirs | QDir::Files | QDir::NoDotAndDotDot);
infolist.append(infolist2);
}else
{
m_filelist<<info.absoluteFilePath();
}
}
}
甚至还使用了迭代器,发现更慢…
void TfileThread::iteratorgetFile(const QString& path)
{
QDirIterator dir_iterator(path,
QDir::Files | QDir::NoSymLinks,
QDirIterator::Subdirectories);
while(dir_iterator.hasNext())
{
dir_iterator.next();
QFileInfo file_info =dir_iterator.fileInfo();
//QString absolute_file_path =file_info.absoluteFilePath();
m_filelist<<file_info.absoluteFilePath();
}
}
运行结果图
————————————————
版权声明:本文为CSDN博主「赢在未来5」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zxy5691419/article/details/106596320
Qt中利用QDirIterator获取目录下的所有文件
您可以使用QDirIterator一次遍历一个目录。它类似于QDir::entryList()和QDir::entryInfoList(),但因为它一次只列出一个条目,而不是一次列出所有条目,它的扩展性更好,更适合大目录。之前我们看到很多用递归的方式进行遍历的,用迭代器方法的效率
用法一:列举全部文件(不包含链接)
。。。。。。。。省略。。。。。。。。。。。。。。
文档是这样说的:Returns the base directory of the iterator.
这个返回的每次都一样,就是你搜索的目录路径,在构造函数里传入的第一个参数,就是它了。
经个人测试,该方法的效率和递归的效率是一样的,可以放心地用。
参考文档:
Qt 遍历文件夹的三种方式
QDirIterator QT遍历目录文件,包括子文件(记录自己获取文件显示不完全的问题)
关于Qt4 QDirIterator遇到中文死循环的问题
QT 读取文件夹下所有文件(超级简单的方法,不需要QDirIterator)
QDir, QFileInfo 和 QDirIterator 区别
遍历文件夹及其子孙文件夹中的文件
————————————————
版权声明:本文为CSDN博主「hp_cpp」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/hp_cpp/article/details/107287135