finddata_t的使用
那么到底如何查找文件呢?我們需要一個(gè)結(jié)構(gòu)體和幾個(gè)大家可能不太熟悉的函數(shù)。這些函數(shù)和結(jié)構(gòu)體在<io.h>的頭文件中,結(jié)構(gòu)體為 struct _finddata_t ,函數(shù)為_findfirst、_findnext和_fineclose.具體如何使用,我會(huì)慢慢講來~
首先講這個(gè)結(jié)構(gòu)體吧~struct _finddata_t ,這個(gè)結(jié)構(gòu)體是用來存儲(chǔ)文件各種信息的。說實(shí)話,這個(gè)結(jié)構(gòu)體的具體定義代碼,我沒有找到,不過還好,文檔里面在_find里有比較詳細(xì)的成員變量介紹。我基本上就把文檔翻譯過來講吧:
unsigned atrrib:文件屬性的存儲(chǔ)位 置。它存儲(chǔ)一個(gè)unsigned單元,用于表示文件的屬性。文件屬性是用位表示的,主要有以下一些:_A_ARCH(存檔)、_A_HIDDEN(隱 藏)、_A_NORMAL(正常)、_A_RDONLY(只讀)、_A_SUBDIR(文件夾)、_A_SYSTEM(系統(tǒng))。這些都是 在<io.h>中定義的宏,可以直接使用,而本身的意義其實(shí)是一個(gè)無符號(hào)整型(只不過這個(gè)整型應(yīng)該是2的幾次冪,從而保證只有一位為1,而其 他位為0)。既然是位表示,那么當(dāng)一個(gè)文件有多個(gè)屬性時(shí),它往往是通過位或的方式,來得到幾個(gè)屬性的綜合。例如只讀+隱藏+系統(tǒng)屬性,應(yīng)該 為:_A_HIDDEN | _A_RDONLY |_A_SYSTEM .
time_t time_create:這里的time_t是一個(gè)變量類型(長(zhǎng)整型?相當(dāng)于long int?),用來存儲(chǔ)時(shí)間的,我們暫時(shí)不用理它,只要知道,這個(gè)time_create變量是用來存儲(chǔ)文件創(chuàng)建時(shí)間的就可以了。
time_t time_access:文件最后一次被訪問的時(shí)間。
time_t time_write:文件最后一次被修改的時(shí)間。
_fsize_t size:文件的大小。這里的_fsize_t應(yīng)該可以相當(dāng)于unsigned整型,表示文件的字節(jié)數(shù)。
char name[_MAX_FNAME]:文件的文件名。這里的_MAX_FNAME是一個(gè)常量宏,它在<stdlib.h>頭文件中被定義,表示的是文件名的最大長(zhǎng)度。
以此,我們可以推測(cè)出,struct_finddata_t ,大概的定義如下:
struct _finddata_t
{
unsigned attrib;
time_t time_create;
time_t time_access;
time_t time_write;
_fsize_t size;
char name[_MAX_FNAME];
};
前面也說了,這個(gè)結(jié)構(gòu)體是用來存儲(chǔ)文件信息的,那么如何把一個(gè)硬盤文件的文件信息“存到”這個(gè)結(jié)構(gòu)體所表示的內(nèi)存空間里去呢?這就要靠_findfirst、_findnext和_fineclose三個(gè)函數(shù)的搭配使用了。
首先還是對(duì)這三個(gè)函數(shù)一一介紹一番吧……
long _findfirst( char *filespec, struct _finddata_t *fileinfo );
返回值:如果查找成功的話,將返回一個(gè)long型的唯一的查找用的句柄(就是一個(gè)唯一編號(hào))。這個(gè)句柄將在_findnext函數(shù)中被使用。若失敗,則返回-1.
參數(shù):
filespec:標(biāo)明文件的字符串,可支持通配符。比如:*.c,則表示當(dāng)前文件夾下的所有后綴為C的文件。
fileinfo :這里就是用來存放文件信息的結(jié)構(gòu)體的指針。這個(gè)結(jié)構(gòu)體必須在調(diào)用此函數(shù)前聲明,不過不用初始化,只要分配了內(nèi)存空間就可以了。函數(shù)成功后,函數(shù)會(huì)把找到的文件的信息放入這個(gè)結(jié)構(gòu)體中。
int _findnext( long handle, struct _finddata_t *fileinfo );
返回值:若成功返回0,否則返回-1.
參數(shù):
handle:即由_findfirst函數(shù)返回回來的句柄。
fileinfo:文件信息結(jié)構(gòu)體的指針。找到文件后,函數(shù)將該文件信息放入此結(jié)構(gòu)體中。
int _findclose( long handle );
返回值:成功返回0,失敗返回-1.
參數(shù):
handle :_findfirst函數(shù)返回回來的句柄。
大家看到這里,估計(jì)都能猜到個(gè)大概了吧?先用_findfirst查找第一個(gè)文件,若成功則用返回的句柄調(diào)用_findnext函數(shù)查找其他的 文件,當(dāng)查找完畢后用,用_findclose函數(shù)結(jié)束查找。恩,對(duì),這就是正確思路。下面我們就按照這樣的思路來編寫一個(gè)查找C:\WINDOWS文件 夾下的所有exe可執(zhí)行文件的程序。
#include <stdio.h>
#include <io.h>
const char *to_search="C:\\WINDOWS\\*.exe"; //欲查找的文件,支持通配符
int main()
{
long handle; //用于查找的句柄
struct _finddata_t fileinfo; //文件信息的結(jié)構(gòu)體
handle=_findfirst(to_search,&fileinfo); //第一次查找
if(-1==handle)return -1;
printf("%s\n",fileinfo.name); //打印出找到的文件的文件名
while(!_findnext(handle,&fileinfo)) //循環(huán)查找其他符合的文件,知道找不到其他的為止
{
printf("%s\n",fileinfo.name);
}
_findclose(handle); //別忘了關(guān)閉句柄
system("pause");
return 0;
}
當(dāng)然,這個(gè)文件的查找是在指定的路徑中進(jìn)行,如何遍歷硬盤,在整個(gè)硬盤中查找文件呢?大家可以在網(wǎng)絡(luò)上搜索文件遞歸遍歷等方法,這里不再做進(jìn)一步介紹。
細(xì)心的朋友可能會(huì)注意到我在程序的末尾用了一個(gè)system函數(shù)。這個(gè)與程序本身并沒有影響,和以前介紹給大家的使用getchar()函數(shù)的 作用相同,只是為了暫停一下,讓我們能看到命令提示符上輸出的結(jié)果而已。不過system函數(shù)本身是一個(gè)非常強(qiáng)大的函數(shù)。大家可以查查MSDN看看~簡(jiǎn)單 來說,它是一個(gè)C語言與操作系統(tǒng)的相互平臺(tái),可以在程序里通過這個(gè)函數(shù),向操作系統(tǒng)傳遞command命令