fgets(),fscanf(),fprintf()

  功能

      從文件結構體指針stream中讀取數據,每次讀取一行。讀取的數據保存在buf指向的字符數組中,每次最多讀取bufsize-1個字符(第bufsize個字符賦'\0'),如果文件中的該行,不足bufsize個字符,則讀完該行就結束。如若該行(包括最後一個換行符)的字符數超過bufsize-1,則fgets只返回一個不完整的行,但是,緩衝區總是以NULL字符結尾,對fgets的下一次調用會繼續讀該行。函數成功將返回buf,失敗或讀到文件結尾返回NULL。因此我們不能直接通過fgets的返回值來判斷函數是否是出錯而終止的,應該藉助feof函數或者ferror函數來判斷

    函數原型

char *fgets(char *buf, int bufsize, FILE *stream);    

     *buf:字符型指針,指向用來存儲所得數據的地址。

bufsize: 整型數據,指明存儲數據的大小。

*stream: 文件結構體指針,將要讀取的文件流。


stream文件流指針體指向文件內容地址的偏移原則

如果使用fgets()讀取某個文件,第一次讀取的bufsize爲5,而文件的第一行有10個字符(算上'\n'),那麼讀取文件的指針會偏移至當前讀取完的這個字符之後的位置。也就是第二次再用fgets()讀取文件的時候,則會繼續讀取其後的字符。而,如果使用fgets() 讀取文件的時候bufsize大於該行的字符總數加2(多出來的兩個,一個保存文件本身的'\n'換行,一個保存字符串本身的結束標識'\0'),文件並不會繼續讀下去,僅僅只是這一行讀取完,隨後指向文件的指針會自動偏移至下一行。

例子

如果一個文件的當前位置的文本如下

Love, I Have

Since you can do it.

如果用fgets(str1,6,file1);去讀取

則執行後str1 = "Love," ,讀取了6-1=5個字符

這個時候再執行fgets(str1,20,file1)則執行後str1 = " I Have\n"

而如果

fgets(str1,23,file1);

則執行str1="Love ,I Have",讀取了一行(包括行尾的'\n',並自動加上字符串結束符'\0'),當前文件位置移至下一行,雖然23大於當前行上字符總和,可是不會繼續到下一行。而下一次調用fgets()繼續讀取的時候是從下一行開始讀。

從 handle 指向的文件中讀取一行並返回長度最多爲 length - 1 字節的字符串。碰到換行符(包括在返回值中)、EOF 或者已經讀取了 length - 1 字節後停止(看先碰到那一種情況)。如果沒有指定 length,則默認爲 1K,或者說 1024 字節。

出錯時返回 FALSE。

②fscanf() 

功 能:

從一個流中執行格式化輸入,fscanf遇到空格和換行時結束,注意空格時也結束。這與fgets有區別,fgets遇到空格不結束。

用 法: int fscanf(FILE *stream, char *format,[argument...]);

int fscanf(文件指針,格式字符串,輸入列表);

   

常用基本參數對照:

%d:讀入一個十進制整數.

%i :讀入十進制,八進制,十六進制整數,與%d類似,但是在編譯時通過數據前置來區分進制,如加入“0x”則是十六進制,加入“0”則爲八進制。例如串“031”使用%d時會被算作31,但是使用%i時會算作25.

%u:讀入一個無符號十進制整數.

%f %F %g %G : 用來輸入實數,可以用小數形式或指數形式輸入.

%x %X: 讀入十六進制整數.

%o': 讀入八進制整數.

%s : 讀入一個字符串,遇空格結束。

%c : 讀入一個字符。無法讀入空值。空格可以被讀入。

fprintf()

fprintf是C/C++中的一個格式化寫-庫函數,位於頭文件<stdio.h>中,其作用是格式化輸出到一個流/文件中;函數原型爲int fprintf( FILE *stream, const char *format, [ argument ]...),fprintf()函數根據指定的格式(format)向輸出流(stream)寫入數據(argument)。

2.fprintf(stdout,“hello world\n”)



  

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章