递归搜索所有文件目录

        依稀记得当时写远程控制软件,想全盘搜索QQ.exe文件路径,网上虽然看了很多代码,但是似乎都没理顺,隔了好几年,重新回顾,根据数据结构的思想,特别是二叉树那一章节给了我很大的启发,终于完成了个人感觉比较简洁的代码。

#include <iostream>
#include <windows.h>
using namespace std;

/********************************************************************************
功能介绍:重新组织文件或者目录的路径
********************************************************************************/
inline void GetFileDirPath(char *str, char *dir_name, char *file_dir_name)
{
	memset(str, 0, 500);
	strcpy(str, dir_name);
	strcat(str, "\\");
	strcat(str, file_dir_name);
}

/********************************************************************************
功能介绍:查找某个文件夹中的所有文件和目录,采用递归的方法进行搜索
********************************************************************************/
void FindFile(char *dir_name)
{
	WIN32_FIND_DATA findFileData;
	char str[500];
	GetFileDirPath(str, dir_name, "*.*");		
	HANDLE hnd = FindFirstFile(str, &findFileData);
	if (hnd == INVALID_HANDLE_VALUE)
	{
		return;
	}
	while (true)
	{	
		if (findFileData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)
		{	//搜索到的是文件夹,当然要把 "." , ".." 两种情况给以排除
			if (findFileData.cFileName[0] != '.')
			{
				GetFileDirPath(str, dir_name, findFileData.cFileName);		
				cout << "F  " << str << endl;	//打印该文件路径
				FindFile(str);	//搜索到目录,继续递归寻找
			}
		}
		else	
		{	//搜索到文件
			GetFileDirPath(str, dir_name, findFileData.cFileName);	
			cout << "D  " << str << endl;		//打印该目录路径
		}
		if (!FindNextFile(hnd, &findFileData))
		{
			break;				//目录所搜完毕,则该层递归返回
		}
	}
	FindClose(hnd);
}

void main()
{
	FindFile("F:");	
}



版权声明:本文为hwb_1988原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。