作者:王姍姍,華清遠見嵌入式學院講師。
在標準IO中,對于文件的讀寫無非三種方式:
(1) 每次一個字符的I / O。
(2) 每次一行的I / O。
(3) 直接I / O。
似乎這些函數(shù)看起來很簡單,但只有理解了這些函數(shù),你才知道該如何使用,例如怎樣來判斷讀取的文件是否結束,怎樣來統(tǒng)計文件的行數(shù),等等。
下面先來回顧下讀取文件的三種方式,然后再舉例看下怎樣使用。
一次讀或寫一個字符,使用getc、fgetc或getchar。如果流是帶緩存的,則標準I / O函數(shù)處理所有緩存。三個函數(shù)原型如下:
#include <stdio.h>
int getc(FILE *fp) ;
int fgetc(FILE *fp) ;
int getchar(void);
三個函數(shù)的返回:若成功則為下一個字符,若已處文件尾端或出錯則為E O F。強調(diào)的是不管是出錯還是到達文件尾端,這三個函數(shù)都返回同樣的值。為了區(qū)分這兩種不同的情況,必須調(diào)用ferror()或feof()。
一次讀或寫一行,使用f g e t s和gets。兩個函數(shù)原型如下:
#include <stdio.h>
Char *gets(char *s) ;
Char *fgets(char *s,int size,FILE *steam)
兩個函數(shù)返回:若成功則為buf,若已處文件尾端或出錯則為null。這兩個函數(shù)都指定了緩存地址,讀入的行將送入其中。gets()從標準輸入讀,而fgets()則從指定的流讀。
對于fgets(),必須指定緩存的長度為n。此函數(shù)一直讀到下一個新行符為止,但是不超過n-1個字符,讀入的字符被送入緩存,該緩存以null字符結尾。如若該行,包括最后一個新行符的字符數(shù)超過n-1,則只返回一個不完整的行,而且緩存總是以null字符結尾。對fgets()的下一次調(diào)用會繼續(xù)讀該行。
直接I / O使用的是fread。每次I / O操作讀某種數(shù)量的對象,而每個對象具有指定的長度。這個函數(shù)常用于從二進制文件中讀一個結構。原型如下:
int fread(void * ptr,int objsize,int objnum,FILE *fp);
這個函數(shù)返回:讀的對象數(shù)。fputs()在遇到null字節(jié)時就停止,而在結構中可能含有null字節(jié),所以不能使用每次一行函數(shù)實現(xiàn)這種要求,而fread能使我們一次讀整個結構。
下面看下如何利用上面提到的標準IO讀函數(shù)來判斷你讀取的文件是否結束以及如何來統(tǒng)計文件的行數(shù)。
1、判斷文件結束有三種方式:
a) 當用fgetc(src)返回的int值為EOF時,讀到文件的末尾
b) 當用fgets(p,1024,src)返回的指針為NULL時,讀到文件的末尾
c) 當用fread(s,1,20,src)返回的個數(shù)小于20時,讀到文件的末尾
實現(xiàn)起來簡單明了,就不再細說。
2、統(tǒng)計文件的行數(shù)
a) 當用fgetc(src)返回的int值為’n’時行數(shù)加一
b) 當用fgets(p,1024,src)返回的指針不為NULL時,你的緩沖即提供的p[1024]已經(jīng)讀到字符,這個時候實際上有兩種情況,一種你讀進來的字符長度小于1024個,這個時候一行結束,行數(shù)加一,另一種比較復雜,由于受自己定義的緩沖的限制,一次只能讀進來1023個,如果恰好這個時候你剛好讀完一行,那p[]1022]里存放的一定’n’,如果不是,那你的一行還一定沒有結束了。
程序如下:
Int n;
A) While(fgetc(src)==’n’)
N++;
B) while(fgets(p,1024,src)!=NULL)
{
If(strlen(p)<1024||p[1022]==’n’)
N++;
}
“本文由華清遠見http://www.embedu.org/index.htm提供”
來源:華清遠見0次