C语言fwrite写入文件可以参考以下的代码:
// 定义一个学生结构体
struct Student_type
{
char name[10];
int num;
int age;
char addr[30];
}stud[40];
int i;
FILE *fp; // 定义一个文件指针fp
fp = fopen("stu.dat", "wb"); // 以二进制可写方式打开stu.dat文件
// 将40个学生的记录写入文件stu.dat中
for(i=0; i<40; i++)
fwrite(&stud[i], sizeof(struct Student_type), 1, fp);
扩展资料:
fwrite函数用法
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函数写到用户空间缓冲区,并未同步到文件中,所以修改后要将内存与文件同步可以用fflush(FILE *fp)函数同步。
参考资料来源:百度百科-fwrite
首先你得rgb本身就是地址应该不用&rgb,直接rgb就行,居然能正确写进去我感觉很诡异……
fwrite参见http://www.cplusplus.com/reference/cstdio/fwrite/
第二个参数是你rgb的一个元素占多少字节(因为是char所以应该写1)
第三个参数是你rgb要写多少个元素,写几个就是几。
fwrite的第一个指针是无类型的,所以第二个参数的单位就是字节。
所以最规范的写法应该是fwrite(rgb,sizeof(char),3,file);这样。
不过由于你是连续读的,也是连续写的,所以一口气读1字节写3次(fwrite(rgb,1,3,file))和一口气读3字节写1次(fwrite(rgb,3,1,file))刚好效果一样而已。
0xCC是因为是写3,2就一共从rgb里去了6个元素,后面的内存是没有定义的,在debug模式下,一些编译环境(比如VS)会将未定义的内存先存入0xCC(使用/GZ开关)(这样你debug是看到一堆CC就说明你内存访问越界了)
最后解决你最后的问题
首先你要rgb[6]来吧内存分配好,不然还会CC。然后最规范的写法是
第一组rgb
fwrite(rgb,sizeof(char),3,file);
第二组rgb
fwrite(rgb+3*sizeof(char),sizeof(char),3,file);
//这里rgb+33*sizeof(char)等价于&rgb[3]
fwrite函数在写文件时是以二进制形式进行的。
函数原型:int fwrite(char *ptr, unsigned size, unsigned n, FILE *fp);
功 能:将ptr所指向的n*size个字节输出到fp所指向的文件中
返 回 值:写到fp文件中的数据项的个数
举例说明如下:
// 定义一个学生结构体
struct Student_type
{
char name[10];
int num;
int age;
char addr[30];
}stud[40];
int i;
FILE *fp; // 定义一个文件指针fp
fp = fopen("stu.dat", "wb"); // 以二进制可写方式打开stu.dat文件
// 将40个学生的记录写入文件stu.dat中
for(i=0; i<40; i++)
fwrite(&stud[i], sizeof(struct Student_type), 1, fp);
改成:fwrite(rgb, 3,1,file) 或者 fwrite(rgb, sizeof(rgb), 1, file)