原創(chuàng)內(nèi)容磅摹,轉(zhuǎn)載請(qǐng)標(biāo)明原文地址
我們先來看下下面的代碼
//獲取文件大小
DWORD Get_File_Size(const char* m_FilePath)
{
unsigned long size;
if (_access(m_FilePath, 0) == -1)//文件不存在 2013.09.24
return 0;
FILE* fp = fopen( m_FilePath, "rb" );
if(fp==NULL)
return 0;
fseek( fp, SEEK_SET, SEEK_END );
size=ftell(fp);
fclose(fp);
return size;
}
BYTE bReadBuf[1024*100];
DWORD dwFileSize = Get_File_Size("C:\\pub.txt");
AfxMessageBox(IntToStr(dwFileSize));
FILE *fp = fopen("C:\\pub.txt","rb");
if (fp != NULL)
{
fread(bReadBuf,dwFileSize,1,fp);
if (!feof(fp))
AfxMessageBox("1");
else
AfxMessageBox("2");
int nRe = fread(bReadBuf,1,1,fp);
AfxMessageBox(IntToStr(nRe));
if (!feof(fp))
AfxMessageBox("1");
else
AfxMessageBox("2");
fclose(fp);
}
其中pub.txt的文件屬性為
彈出的內(nèi)容分別為64鳞疲,1秧骑,0版确,2
獲取出來的文件大小是正確的,但是如果按照這個(gè)大小去讀取的話乎折,是會(huì)發(fā)現(xiàn)绒疗,feof返回的是true,但是繼續(xù)去讀取的話骂澄,又讀取不出來數(shù)據(jù)吓蘑,但是這個(gè)時(shí)候再次判斷feof則返回false了,
原因在于坟冲,feof只有只有在讀取超過的情況下磨镶,才會(huì)返回false