依稀记得当时写远程控制软件,想全盘搜索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:");
}