欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言文件操作中 fgets與fputs 函數(shù)詳解

 更新時間:2017年06月16日 10:15:43   投稿:lqh  
這篇文章主要介紹了C語言文件操作中 fgets與fputs 函數(shù)詳解的相關(guān)資料,需要的朋友可以參考下

C語言文件操作中 fgets、fputs 函數(shù)詳解

先給出api

fgets 
語法: 
 #include <stdio.h>
 char *fgets( char *str, int num, FILE *stream );

函數(shù)fgets()從給出的文件流中讀取[num - 1]個字符并且把它們轉(zhuǎn)儲到str(字符串)中. fgets()在到達行末時停止,在這種情況下,str(字符串)將會被一個新行符結(jié)束. 如果fgets()達到[num - 1]個字符或者遇到EOF, str(字符串)將會以null結(jié)束.fgets()成功時返回str(字符串),失敗時返回NULL.

自己理解

1、每次讀取一行,如果讀取的一行字符數(shù) len  > bufsize-1,則 buf[ bufsize-1 ] = '0'

       文件句柄指向第bufsize的位置。

2、每次讀取一行,如果讀取的一行字符數(shù) len = bufsize-1,則 buf[ bufsize-1 ] = '0'

         文件句柄指向第bufsize的位置。

3、每次讀取一行,如果讀取的一行字符數(shù)  len < bufsize-1,則 buf [ len-1 ] = '\n' , buf [ len ] = '\0'

         文件句柄指向下一行的首位置。

驗證代碼:

int i=0;
 FILE *fp;
 char buff[5];
 //將數(shù)組賦值為9,便于后面與賦值的地方比較 
 memset(buff,9,sizeof(buff));
 
 char *fName = "d:/123.txt"; 
 fp = fopen(fName,"r");
 fgets(buff,sizeof(buff),fp);
 
 //打印出數(shù)組的ascii碼 
 printf("buff數(shù)組內(nèi)容:\n");
 for(i=0;i<sizeof(buff);i++)
 {
 printf("%d ",(int)buff[i]); 
 }
 printf("\n");
 
 //繼續(xù)獲取下一行字符,驗證文件句柄的位置
 memset(buff,9,sizeof(buff));
 fgets(buff,sizeof(buff),fp);
 //打印出數(shù)組的ascii碼 
 printf("下一行buff數(shù)組內(nèi)容:\n");
 for(i=0;i<sizeof(buff);i++)
 {
 printf("%d ",(int)buff[i]); 
 }
 printf("\n");
 
 fclose(fp);

123.txt 文件內(nèi)容:

1234
asdf

輸出結(jié)果:

buff長度為4,驗證理解1

buff數(shù)組內(nèi)容:

49 50 51 0
下一行buff數(shù)組內(nèi)容:
52 10 0 9
 

buff長度為5,驗證理解2

buff數(shù)組內(nèi)容:
49 50 51 52 0
下一行buff數(shù)組內(nèi)容:
10 0 9 9 9

buff長度為10,驗證理解3

buff數(shù)組內(nèi)容:

49 50 51 52 10 0 9 9 9 9
下一行buff數(shù)組內(nèi)容:
97 115 100 102 0 9 9 9 9 9

 文件寫入數(shù)據(jù)本質(zhì):

將字符串插入到文件中,在字符串的結(jié)尾處插入換行符'\n'

fgets函數(shù)本質(zhì):

按照需要寫入的緩存空間大小,將文件中的buffsize-1個字符寫入到緩存空間,將緩存空間的buffsize位置寫入'\0'字符。

fputs函數(shù)本質(zhì):

將指定的字符串寫入文件流中,不包含字符串結(jié)尾符'\0',利用它可以替換文件流中數(shù)據(jù),但是不能添加數(shù)據(jù)。

驗證代碼

  FILE *fp;
 char *fName = "d:/123.txt"; 
 fp = fopen(fName,"r+");
 fseek(fp,3,SEEK_CUR);
 fputs("Insert Strings",fp);
 fclose(fp);

原文件內(nèi)容:

1234
Second Line. Second Strings.

修改后文件內(nèi)容:

123Insert Strings. Second Strings.

可以看出,將原文件中的“\n及Second Line.” 替換為了“Insert Strings.”

fputc函數(shù)本質(zhì):

函數(shù)fputc()把給出的字符ch寫到給出的輸出流中的指定位置. 返回值是字符, 發(fā)生錯誤時返回值是EOF. 可以替換文件流中數(shù)據(jù),但是不能添加數(shù)據(jù)。

fgetc函數(shù)本質(zhì):

fgetc()函數(shù)返回來自stream(流)中的下一個字符,如果到達文件尾或者發(fā)生錯誤時返回EOF. 是什么字符,就返回什么字符(包括'\0','\n')。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • 深入探究C/C++中互斥量(鎖)的實現(xiàn)原理

    深入探究C/C++中互斥量(鎖)的實現(xiàn)原理

    ? 互斥量是一種同步原語,用于保護多個線程同時訪問共享數(shù)據(jù),互斥量提供獨占的、非遞歸的所有權(quán)語義,本文將和大家一起深入探究C/C++中互斥量(鎖)的實現(xiàn)原理,感興趣的小伙伴跟著小編一起來看看吧
    2024-06-06
  • 使用VScode搭建ROS開發(fā)環(huán)境的教程詳解

    使用VScode搭建ROS開發(fā)環(huán)境的教程詳解

    這篇文章主要介紹了使用VScode搭建ROS開發(fā)環(huán)境,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • C語言實現(xiàn)頁面置換 先進先出算法(FIFO)

    C語言實現(xiàn)頁面置換 先進先出算法(FIFO)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)頁面置換,先進先出算法(FIFO),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • 一篇文章帶你了解C++特殊類的設(shè)計

    一篇文章帶你了解C++特殊類的設(shè)計

    這篇文章主要為大家詳細介紹了C++特殊類的設(shè)計,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • C語言學習基礎(chǔ)知識分享

    C語言學習基礎(chǔ)知識分享

    這篇文章主要介紹了C語言學習基礎(chǔ)知識分享的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • 舉例分析private的作用(c/c++學習)

    舉例分析private的作用(c/c++學習)

    我知道我們可以用 public 中的值,把private中的數(shù)據(jù)給提出來,但是還是搞不懂private該怎么用,或者說在一個具體程序中,private有什么用
    2020-08-08
  • C++設(shè)計模式之代理模式

    C++設(shè)計模式之代理模式

    這篇文章主要介紹了C++設(shè)計模式之代理模式,本文講解了什么是代理模式、代理模式的使用場合、代理模式的實現(xiàn)代碼等內(nèi)容,需要的朋友可以參考下
    2014-10-10
  • C++內(nèi)存管理介紹

    C++內(nèi)存管理介紹

    這篇文章主要介紹了C++內(nèi)存管理,C++標準委員會給我們提供了auto_ptr智能指針,后面又引入了share_ptr以及weak_ptr幫助我們正確和安全的使用指針,本文主要是介紹boost庫提供的解決方案,需要的朋友可以參考一下
    2022-01-01
  • C++ 使用CRC32檢測內(nèi)存映像完整性的實現(xiàn)步驟

    C++ 使用CRC32檢測內(nèi)存映像完整性的實現(xiàn)步驟

    當我們使用動態(tài)補丁的時候,那么內(nèi)存中同樣不存在校驗效果,也就無法抵御對方動態(tài)修改機器碼了,為了防止解密者直接對內(nèi)存打補丁,我們需要在硬盤校驗的基礎(chǔ)上,增加內(nèi)存校驗,防止動態(tài)補丁的運用。
    2021-06-06
  • C++并查集算法簡單詳解

    C++并查集算法簡單詳解

    大家好,本篇文章主要講的是C++并查集算法簡單詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02

最新評論