方法:如何解决CFindFile:FindNextFile找不到最后一个文件

来源:互联网 发布:网络监控系统原理图 编辑:程序博客网 时间:2024/06/16 22:52
转载请注明来源:http://www.cnblogs.com/xuesongshu/

  在网上搜索到的一些遍历算法不仅繁锁,而且存在抄袭现象,而且抄袭的对象有问题,因为他们忽视了一个FindNextFile的一个很重要的问题。在这里我把对问题的分析以及我的方法分享给大家。

  首先说明一下,Windows把所有数据单元称为文件,目录(即文件夹)也不例外。它有一个宏定义FILE_ATTRIBUTE_DIRECTORY标记注明该文件记录的是文件系统信息,而不是用户数据。目录与普通文件的一个重要区别是目录存储的是别的文件的信息。而普通文件记录的才是用户想要存储的数据。

  实践证明,当FindNextFile找到最后一个文件时,它的返回值是FALSE。所以这个返回值我认为需要重新理解:它表示下次再执行该方法时找不到当前目录下的其它文件记录,不是表示本次没有找到。如果我们把文件系统对一个一个的文件的记录理解为单向链表,那么返回值FALSE表示下一个结点是NULL。

  知道了问题,那么遍历算法可以这样写:

CFileFind ff;BOOL bFind=ff.FindFile("c:\\*.*");CString szFileName=L"";do {bFind=ff.FindNextFile();if (ff.IsDots()){continue;}szFileName=ff.GetFileName();if (szFileName.IsEmpty()){break;}if (!ff.IsDirectory()){InsertItem(0,szFileName.GetBuffer(szFileName.GetLength()));}} while (bFind);

  

  网上还搜到了一些方法,如何判断当前对象是不是目录(文件夹)。方法是调用shellapi。我认为大可不必如此麻烦,请看我的方法:

BOOL isDirectory=::GetFileAttributes(szFullPath)&FILE_ATTRIBUTE_DIRECTORY;

  呵呵,又提到了FILE_ATTRIBUTE_DIRECTORY。我认为这才是微软的初忠。

1 0
原创粉丝点击