前幾天在工作中需要寫一段代碼,獲取一些視頻文件的大小,心想:這還不簡(jiǎn)單嗎?直接用標(biāo)準(zhǔn)C 的文件操作函數(shù)就OK了。于是寫了下面的一段代碼來實(shí)現(xiàn):
unsigned long get_file_size(const char *filename)
{
unsigned long size;
FILE* fp = fopen( filename, "rb" );
if(fp==NULL)
{
printf("ERROR: Open file %s failed.\n", filename);
return 0;
}
fseek( fp, SEEK_SET, SEEK_END );
size=ftell(fp);
fclose(fp);
return size;
}
沒有想到的是,在程序執(zhí)行后發(fā)現(xiàn)有的文件能正確的獲取大小,而有的文件則不能正確的獲取到文件大小,檢查了代碼,也沒有發(fā)現(xiàn)有什么不對(duì)的地方。但是在這過程中發(fā)現(xiàn)了一個(gè)問題,就是能正確獲取大小的文件都是相對(duì)比較小的文件,而出現(xiàn)錯(cuò)誤的都是很大的文件。于是想到會(huì)不會(huì)是因?yàn)闃?biāo)準(zhǔn)C文件操作函數(shù)對(duì)超過一定大小的文件不支持所造成的呢,于是Google了一下,沒想到我的猜測(cè)是正確的,標(biāo)準(zhǔn)C的文件操作函數(shù)不支持對(duì)超過2G的文件讀取。
問題找到了,看來只有換一種方法來實(shí)現(xiàn)了,因?yàn)槠綍r(shí)很少用到標(biāo)準(zhǔn)C的一些函數(shù),所以,又只有求助于Google了,在看了網(wǎng)上不少的參考文章之后,發(fā)現(xiàn)調(diào)用stat函數(shù)可以正確的得到超大文件的狀態(tài)信息(當(dāng)然包括文件大小),于是最終實(shí)現(xiàn)了如下的代碼:
unsigned long get_file_size(const char *filename)
{
struct stat buf;
if(stat(filename, &buf)<0)
{
return 0;
}
return (unsigned long)buf.st_size;
}
從寫這么一個(gè)小小功能的函數(shù)可以看出,平時(shí)多積累一些計(jì)算機(jī)方面的知識(shí)真的是很重要的,同時(shí)對(duì)代碼的全面測(cè)試也是相當(dāng)重要的,否則,看著很正確的代碼可能在某些情況下會(huì)給你帶來意想不到的麻煩。