1. 程式人生 > >C/C++遍歷目錄下的所有文件(Windows/Linux篇,超詳細)

C/C++遍歷目錄下的所有文件(Windows/Linux篇,超詳細)

檢查 msd 字符 size tro 也會 結構 () alt

前面的一篇文章我們講了用Windows API遍歷一個目錄下的所有文件,這次我們講用一種Windows/Linux通用的方法遍歷一個目錄下的所有文件。

Windows/Linux的IDE都會提供一個頭文件——<io.h>。看名字,似乎是關於I/O的,但是實際上它還提供了類似於WIN32_FIND_DATA、FindFirstFile()、FindNextFile()和FindClose()的查找文件的功能。

_finddata_t結構

_finddata_t結構用來記錄查找到的文件的信息。實際上有_finddata32_t、_finddata32i64_t、_finddata64i32_t、_finddata64_t、_wfinddata32_t、_wfinddata32i64_t、_wfinddata64i32_t、_wfinddata64_t八個結構,但都只是在32位/64位整數和字符類型上有所區別,但整體上相同。大致定義如下(MSDN):

struct _finddata_t
{
    unsigned attrib;
    size_t time_create;
    size_t time_access;
    size_t time_write;
    _fsize_t size;
    char name[_MAX_PATH];
};

對於不同的_finddata_t結構,time_create、time_access和time_write的類型為_time32_t或_time64_t,size的類型為_fsize_t或__int64,name為char[_MAX_PATH]或wchar_t[_MAX_PATH]。

attrib

unsigned類型,文件屬性。

time_create

_time32_t/_time64_t類型,文件創建時間(FAT文件系統為-1)。以UTC格式存儲,如果需要轉換成當地時間,使用localtime_s()。

time_access

_time32_t/_time64_t類型,文件最後一次被訪問的時間(FAT文件系統為-1)。以UTC格式存儲,如果需要轉換成當地時間,使用localtime_s()。

time_write

_time32_t/_time64_t類型,文件最後一次被寫入的時間。以UTC格式存儲,如果需要轉換成當地時間,使用localtime_s()。

size

_fsize_t/__int64類型,文件的長度(以字節為單位)。

name

char[_MAX_PATH]/wchar_t[_MAX_PATH]類型,文件/目錄名,不包含路徑。

對於不支持文件創建時間、文件上一次訪問時間的文件系統,time_create和time_access為-1。

_MAX_PATH在stdlib.h中被定義為260。

一般_finddata_t被定義為_finddata32_t/_finddata64i32_t,_wfinddata_t被定義為_wfinddata32_t/_wfinddata64i32_t。為方便,下文中將_finddata_t和_wfinddata_t統稱為_finddata_t。

文件屬性常量

一個文件/目錄可以有多種屬性,每種屬性可以是下面列出的屬性之一。

_A_ARCH

檔案。文件被BACKUP指令改變或清除時被設置。值:0x20。

_A_HIDDEN

隱藏。使用DIR指令一般看不到,除非使用/AH選項。值:0x02。

_A_NORMAL

普通。文件沒有更多屬性被設置,可以沒有限制地被讀或寫。值:0x00。

_A_RDONLY

只讀。不能以“寫”為目的打開該文件,並且不能創建同名的文件。值:0x01。

_A_SUBDIR

子目錄。值:0x10。

_A_SYSTEM

系統文件。使用DIR指令一般看不見,除非使用/A或/A:S選項。值:0x04。

要檢查x是否含有某個屬性a,可以用x & a進行檢查。指定多個屬性可以使用按位or運算符,例如_A_SYSTEM | _A_RDONLY | _A_HIDDEN。

通配符(wildcards)

遍歷文件目錄時需要使用通配符,詳見<psg>。

_findfirst()/_findnext()/_findclose()函數

_findfirst()函數

intptr_t _findfirst(
    const char * filespec,
    struct _finddata_t *fileinfo
);

實際上_findfirst()有10個版本,這裏只列出一個。

filespec

const char */const wchar_t *類型,目標文件說明(可包含通配符)。

fileinfo

_finddata_t *類型,函數將會填入文件/目錄信息。

返回值

如果成功,返回一個唯一的搜索句柄標識一個或一組和filespec說明匹配的文件,可以用於接下來的_findnext()和_findclose()函數。否則_findfirst()返回-1。註意,intptr_t並不是指針類型,只是int或__int64的typedef。

_findnext()函數

int _findnext(
    intptr_t handle,
    struct _finddata_t *fileinfo
);

handle

intptr_t類型,搜索句柄。

fileinfo

_finddata_t *類型,函數將會填入文件/目錄信息。

返回值

如果成功,返回0,否則返回-1。如果沒有更多能夠找到的文件了,也會導致失敗。

程序代碼

C/C++遍歷目錄下的所有文件(Windows/Linux篇,超詳細)