fprintf 和 fwrite的區別

weixin_34262482發表於2010-10-08

程式碼1:
  #include <stdio.h>
  #include <stdlib.h>
  int main( void )
  {
    int i ;
    int buffer[10];
    FILE *fp;
    if((fp=fopen("e:\\cx\\72\\未命名29.c", "wb+" )) == NULL )
    {
      printf("不能開啟檔案\n");
      getch();
      exit(1);
    }

    for (i=0; i<10; i++)
    {
      scanf("%d", &buffer) ;
    }
  

    for (i=0; i<10; i++)
    {
        fprintf(fp, "%d", buffer);
    }
    fclose(fp);
    system("pause");
    return 0;
  }

程式碼2:
  int main(void)
  {
    int i, count;
    int buffer[10];
    int array[10];
    FILE *fp;
    for (i=0; i<10; i++)
    {
      scanf("%d", &buffer);
    }

   if ((fp=fopen("e:\\cx\\72\\未命名29.c", "wb+")) == NULL)
    {
      printf("不能開啟檔案\n");
      getch();
      exit(0);
    }

    for (i=0; i<10; i++)
    {
      fwrite(&buffer, sizeof(int), 1, fp);
    }
    fclose(fp);
    system("pause");
    return 0;
  }

這兩段程式碼就是有顏色的地方不一樣. 但這兩段程式碼經過執行後,為什麼檔案的位元組數不等?

輸入: 1 2 3 4 5 6 7 8 9 0
程式碼1結果: 10個位元組
程式碼2結果: 40個位元組

==================
fwrite 函式按照指定的資料型別將矩陣中的元素寫入到檔案中。寫二進位制檔案
其呼叫格式為:COUNT=fwrite (fid, A, precision)其中COUNT返回所寫的資料元素個數,fid為檔案控制程式碼,A用來存放寫入檔案的資料,precision用於控制所寫資料的型別,其形式與fread函式相同。



fprintf 寫文字檔案 函式的呼叫格式為:COUNT= fprintf(fid, format, A)其中A存放要寫入檔案的資料。先按format指定的格式將資料矩陣A格式化,然後寫入到fid所指定的檔案。format用以控制讀取的資料格式, 由%加上格式符組成,常見的格式符有d,f,c,s。fid為檔案控制程式碼。

====


fprintf(fp, "%d", buffer); 是將格式化的資料寫入檔案
fprintf(檔案指標,格式字串,輸出表列);

fwrite(&buffer, sizeof(int), 1, fp);是以二進位位方式寫入檔案
fwrite(資料,資料型別大小(位元組數),寫入資料的最大數量,檔案指標);

由於fprintf寫入時,對於整數來說,一位佔一個位元組,比如1,佔1個位元組;10,佔2個位元組;100,佔3個位元組,10000,佔5個位元組
所以檔案的大小會隨資料的大小而改變,對大資料空間佔用很大。
而fwrite是按二進位制寫入,所以寫入資料所佔空間是根據資料型別來確定,比如int的大小為4個位元組(一般32位下),那麼整數10所佔空間為4個位元組,100、10000所佔空間也是4個位元組。所以二進位制寫入比格式化寫入更省空間。

因此,
對於1 2 3 4 5 6 7 8 9 0 十個整數,用fprintf寫入時,佔10個位元組;而用fwrite寫入時,佔40個位元組。
對於100 101 102 103 104 105 106 107 108 109 110 這十個整數,用fprintf寫入時,佔30個位元組;而用fwrite寫入時,佔40個位元組。
對於10000 10100 10200 10300 10400 10500 10600 10700 10800 10900 11000 這十個整數,用fprintf寫入時,佔50個位元組;而用fwrite寫入時,還是佔40個位元組。