程式碼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個位元組。