1.函數功能
用來讀寫一個數據塊。
2.一般調用形式
fread(buffer,size,count,fp);
fwrite(buffer,size,count,fp);
3.說明
(1)buffer:是一個指針,對fread來說,它是讀入數據的存放地址。對fwrite來說,是要輸出數據的地址。
(2)size:要讀寫的字節數;
(3)count:要進行讀寫多少個size字節的數據項;
(4)fp:文件型指針。
注意:1 完成次寫操(fwrite())作後必須關閉流(fclose());
2 完成一次讀操作(fread())後,如果沒有關閉流(fclose()),則指針(FILE * fp)自動向後移動前一次讀寫的長度,不關閉流繼續下一次讀操作則接着上次的輸出繼續輸出;
3 fprintf() : 按格式輸入到流,其原型是int fprintf(FILE *stream, const char *format[, argument, ...]);其用法和printf()相同,不過不是寫到控制檯,而是寫到流罷了。注意的是返回值爲此次操作寫入到文件的字節數。如int c = fprintf(fp, "%s %s %d %f", str1,str2, a, b) ;str1:10字節;str2: 10字節;a:2字節;b:8字節,c爲33,因爲寫入時不同的數據間自動加入一個空格。
文件使用之後一定要關閉,否則將不能正確顯示內容.fwrite:讀入兩個學生信息然後用fwrite存入文件
fread:用fread從文件中讀出學生信息。
fwrite.c
#include <stdio.h>
#define SIZE 2
struct student_type
{
char name[10];
int num;
int age;
char addr[10];
}stud[SIZE];
void save()
{
FILE *fp;
int i;
if((fp=fopen("stu_list","wb"))==NULL)
{
printf("cant open the file");
exit(0);
}
for(i=0;i<SIZE;i++)
{
if(fwrite(&stud[i],sizeof(struct student_type),1,fp)!=1)
printf("file write error\n");
}
fclose(fp);
}
main()
{
int i;
for(i=0;i<SIZE;i++)
{
scanf("%s%d%d%s",&stud[i].name,&stud[i].num,&stud[i].age,&stud[i].addr);
save();
}
for(i=0;i<SIZE;i++)
{
printf("%s,%d,%d",stud[i].name,stud[i].num,stud[i].age,stud[i].addr);
}
}
fread.c
#include <stdio.h>
#define SIZE 2
struct student_type
{
char name[10];
int num;
int age;
char addr[10];
}stud[SIZE];
void read()
{
FILE *fp;
int i;
if((fp=fopen("stu_list","rb"))==NULL)
{
printf("cant open the file");
exit(0);
}
for(i=0;i<SIZE;i++)
{
if(fread(&stud[i],sizeof(struct student_type),1,fp)!=1)
printf("file write error\n");
}
fclose(fp);
}
main()
{
int i;
read();
for(i=0;i<SIZE;i++)
{
printf("%s,%d,%d,%s",stud[i].name,stud[i].num,stud[i].age,stud[i].addr);
printf("\n");
}
}
在C語言中進行文件操作時,我們經常用到fread()和fwrite(),用它們來對文件進行讀寫操作。下面詳細紹一下這兩個函數的用法。
我們在用C語言編寫程序時,一般使用標準文件系統,即緩衝文件系統。系統在內存中爲每個正在讀寫的文件開闢“文件緩衝區”,在對文件進行讀寫時數據都經過緩衝區。要對文件進行讀寫,系統首先開闢一塊內存區來保存文件信息,保存這些信息用的是一個結構體,將這個結構體typedef爲FILE類型。我們首先要定義一個指向這個結構體的指針,當程序打開一個文件時,我們獲得指向FILE結構的指針,通過這個指針,我們就可以對文件進行操作。例如:
#i nclude <stdio.h>
#i nclude <string.h>
int main()
{
FILE *fp;
char buffer[100] = "This is a test";
if((fp = fopen("c:\\example.txt", "w")) == 0)
{
printf("open failed!");
exit(1);
}
fwrite(buffer, 1, strlen("This is a test"), fp);
fclose(fp);
return 0;
}
通過以上代碼,我們就在c盤的根目錄下建立了一個名爲example擴展名爲.txt的文件,我們打開可以看到上面寫上了This is a test。當我們對它將它讀出時,用如下代碼:
#i nclude <stdio.h>
#i nclude <mem.h>
int main()
{
FILE *fp; int len;
char buffer[100];
/*memset(buffer, 1, 100); */
if((fp = fopen("c:\\example.txt", "r")) == 0)
{
printf("open failed!");
exit(1);
}
fseek(fp, 0L, SEEK_END);
len = ftell(fp);
rewind(fp);
fread(buffer, 1, len , fp);
printf("%s",buffer);
fclose(fp);
getch();
return 0;
}
可以看到,當我們使用memset了以後,讀出了一大堆亂碼,這是爲什麼呢?原因是我們在fwrite函數時寫入的字節數是用strlen求得的,也就是說字符串最後的'\0'並沒有寫到文件中去。所以我們從文件中讀到buffer中時也自然沒有'\0',因爲buffer中的數是隨機的,除非buffer中最後一個字符的下一個數恰好隨機到0(可能性很小,這裏用memset將它排除),否則以%s將buffer中的字符輸出時遇不到0,所以亂碼產生。解決的辦法有很多,你可以在向文件寫數據時多寫入一個字節,系統會自動寫入0,fwrite(buffer,
1, strlen("This is a test")+1, fp);這樣讀出時最後就有一個0了。或者讀出操作完成後,在最後一個字符後面補上一個0:buffer[len] = 0;這樣問題也可得到解決。
本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/greytree/archive/2006/06/02/769952.aspx
文章轉自:http://www.cnblogs.com/witxjp/archive/2011/03/21/1990519.html