用法:
size_t fwrite(const void* buffer, size_t size, size_t count, FILE* stream)
注意:这个函数以二进制形式对文件进行操作,不局限于文本文件
返回值:返回实际写入的数据块数目
(1)buffer:是一个指针,对fwrite来说,是要获取数据的地址;
(2)size:要写入内容的单字节数;
(3)count:要进行写入size字节的数据项的个数;
(4)stream:目标文件指针;
(5)返回实际写入的数据项个数count。
说明:写入到文件的哪里? 这个与文件的打开模式有关,如果是w+,则是从file pointer指向的地址开始写,替换掉之后的内容,文件的长度可以不变,stream的位置移动count个数;如果是a+,则从文件的末尾开始添加,文件长度加大。
fseek对此函数有作用,但是fwrite[1] 函数写到用户空间缓冲区,并未同步到文件中,所以修改后要将内存与文件同步可以用fflush(FILE *fp)函数同步。
程序示例:
示例一:
#include <stdio.h>
struct mystruct
{
int i
char cha
}
int main(void)
{
FILE *stream
struct mystruct s
if ((stream = fopen("TEST.$$$", "wb")) == NULL) /* open file TEST.$$$ */
{
fprintf(stderr, "Cannot open output file.\n")
return 1
}
s.i = 0
s.cha = 'A'
fwrite(&s, sizeof(s), 1, stream)/* 写的struct文件*/
fclose(stream)/*关闭文件*/
return 0
}
示例二:
#include<stdio.h>
#define SIZE 1
typedef struct
{
char name[10]
int num
int age
char addr[15]
}student
student stu[SIZE]
void save()
{
FILE *fp
int i
if((fp=fopen("dat.txt","w"))==NULL)
{
printf("无法打开此文件!\n")
return
}
for(i=0i<SIZEi++)
if(fwrite(&stu[i], sizeof(student), 1, fp) != 1)
printf("文件写入错误。!\n")
fclose(fp)
}
void main()
{
int i
for(i=0i<SIZEi++)
scanf("%s%d%d%s",&stu[i].name,&stu[i].num,&stu[i].age,&stu[i].addr)
save()
}
scanf("%1d,%s,%d,%f",&tea[i].num,tea[i].name,&tea[i].age,&tea[i].salary)要求输入的格式是用逗号分隔的,所以,你要console输入要使用逗号分隔符。在控制台输入 1,aaa,24,3000回车。
scanf的第一个参数是格式化字符串,后面是可变长参数列表,要求是指针类型,tea[i].name代表tea数组的第i个元素中的name,name会从char[]类型隐式转型为char *,也就是字符数组首地址。
所以不需要取地址&。
fwrite是向文件中写入你之前输入的内容,该内容是二进制的,因为你打开的时候是用的wb,w是写的意思,b是binary的意思。你向文件中写入了这个结构体二进制数据。&tea[i]就是tea[i]的地址,sizeof(struct teacher)返回结构体teacher的大小。
fwrite(a,sizeof(int),
5,
fp)
a表示待写入数据的起始地址
sizeof(int)表示每次写入的数据长度
(sizeof(int)=4字节)
5表示一共写入5次
。和前两个参数结合起来用,就是从a的位置上获得5次数据写入文件中,每次获得4字节长度。(本题中,就是指a数组的前5个元素)
fp表示文件句柄(前面用fopen打开的文件)