Linux 下C語(yǔ)言獲取文件大小
C語(yǔ)言是一種比較底層的語(yǔ)言,有時(shí)在其他語(yǔ)言中很容易操作的事情,在c語(yǔ)言中就比較麻煩,例如獲取一個(gè)文件的大小。Java中File類(lèi)有個(gè)length函數(shù),Python中os.path包中有個(gè)getsize函數(shù),C語(yǔ)言中卻沒(méi)有直接對(duì)應(yīng)的函數(shù)獲取文件大小。
目前,網(wǎng)上有一種流傳很廣的方法,讀取文件到內(nèi)存,然后跳轉(zhuǎn)到文件末尾,查看跳轉(zhuǎn)的長(zhǎng)度。代碼如下:
int file_size(char* filename)
{
FILE *fp=fopen(filename,"r");
if(!fp) return -1;
fseek(fp,0L,SEEK_END);
int size=ftell(fp);
fclose(fp);
return size;
}
上述方法利用fseek移動(dòng)一個(gè)文件的存取位置到文件的末尾,然后利用ftell獲得目前的文件訪問(wèn)位置。這種方法可以認(rèn)為是一種間接的獲取方式。雖說(shuō)可以獲得文件大小,但是有兩個(gè)缺點(diǎn)。首先,ftell的返回值為long,在不同環(huán)境下占用的字節(jié)數(shù)也不同,這就可能存在long是四個(gè)字節(jié)的情況。此時(shí),獲取的文件大小就不能超過(guò)2G,否則就會(huì)出錯(cuò)。
但是,上述缺點(diǎn)在大多數(shù)情況下都沒(méi)問(wèn)題,超大文件還可以通過(guò)fsetpos和fgetpos獲取文件大小。最致命的缺陷就是它需要加載文件到內(nèi)存,然后跳轉(zhuǎn)到文件末尾,這個(gè)操作非常耗時(shí)!可能在讀取少量文件時(shí)體現(xiàn)不出,但是當(dāng)文件達(dá)到上萬(wàn)個(gè)時(shí),速度就會(huì)慢的要命,這種方法相當(dāng)于把所有的文件都讀到內(nèi)存中一遍!
如果可能,盡量避免采用上述間接的方式獲取文件大小。在Linux下,還有一種更簡(jiǎn)單的方式,通過(guò)讀取文件信息獲得文件大小,速度也快很多。代碼如下:
#include sys/stat.h>
int file_size2(char* filename)
{
struct stat statbuf;
stat(filename,statbuf);
int size=statbuf.st_size;
return size;
}
這種方式首先獲得相關(guān)文件的狀態(tài)信息,然后從狀態(tài)信息中讀取大小信息。由于沒(méi)有讀取文件的操作,所以操作速度非???。強(qiáng)烈建議大家在linux下使用這種方式。Windows平臺(tái)下肯定也有類(lèi)似的函數(shù)讀取文件信息,不過(guò)本人常年不在windows下編程,所以在此不做介紹。
您可能感興趣的文章:- linux下c語(yǔ)言的多線(xiàn)程編程
- Linux下C語(yǔ)言的幾道經(jīng)典面試題小結(jié)(分享)
- Linux 中C語(yǔ)言getcwd()函數(shù)的用法
- Linux 下C語(yǔ)言連接mysql實(shí)例詳解
- linux C語(yǔ)言開(kāi)發(fā)管道通信實(shí)例詳解
- linux下C語(yǔ)言實(shí)現(xiàn)寫(xiě)日志功能