码迷,mamicode.com
首页 > 编程语言 > 详细

linux c++有序遍历目录

时间:2014-06-08 03:16:36      阅读:245      评论:0      收藏:0      [点我收藏+]

标签:c   class   blog   code   a   http   



readdir读取的顺序貌似没什么规律的。

这里http://bbs.csdn.net/topics/310054496有人说跟每个文件的d_off有关。但在我机器上测试过貌似没有规律。

好吧。

其实我只是需要确保每次遍历文件夹的时候,顺序都是一样的就行了。所以自己排序一下即可。



/**
 * path:目录
 * files:用于保存文件名的vector
 * r:是否需要遍历子目录
 */
void listDir(const char *path,vector<string>& files,bool r = false)
{
	DIR *pDir;
	struct dirent *ent;
	char childpath[512];
	char absolutepath[512];
	pDir = opendir(path);
	memset(childpath, 0, sizeof(childpath));
	while ((ent = readdir(pDir)) != NULL)
	{
		if (ent->d_type & DT_DIR)
		{

			if (strcmp(ent->d_name, ".") == 0 || strcmp(ent->d_name, "..") == 0)
			{
				continue;
			}
			if(r) //如果需要遍历子目录
			{
				sprintf(childpath, "%s/%s", path, ent->d_name);
				listDir(childpath,files);
			}
		}
		else
		{
			sprintf(absolutepath, "%s/%s", path, ent->d_name);
			files.push_back(absolutepath);
		}
	}

	sort(files.begin(),files.end());//排序

}


linux c++有序遍历目录,布布扣,bubuko.com

linux c++有序遍历目录

标签:c   class   blog   code   a   http   

原文地址:http://blog.csdn.net/lingerlanlan/article/details/28602697

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!