需要导入的头文件
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
写入结构体
假设有结构体:
struct Book {
float value;
char title[100];
};
结构体写入文件的方法:
void writeStruct(){
FILE *pFile;
struct Book book;
book.value = 16;
strcpy(book.title, "Hello, world!");
pFile = fopen("test.dat", "wb");
if (pFile == NULL) {
printf("error open");
exit(0);
}
fwrite(&book, sizeof(struct Book), 1, pFile);
fclose(pFile);
}
读取文件中的结构体
void readStruct() {
FILE *pFile;
struct Book book;
pFile = fopen("test.dat", "rb");
if (pFile == NULL) {
printf("error open");
exit(0);
}
while (fread(&book, sizeof(struct Book), 1, pFile) == 1)
printf("%s : %f", book.title, book.value);
fclose(pFile);
}
知识扩展
函数fopen是一个标准c函数,其功能是打开一个文件,之后便可以进行读或写的操作.其原型是这样的:FILE *fopen( const char *filename, const char *mode );
第一个参数是要打开文件的名字(路径),第二个参数是打开文件所用的模式.对于模式参数的”w”和”wb”,”r”和”rb”,我起初并不是很理解,按照课本上的说法,”w”是以文本的形式进行写入,而”wb”是以二进制模式进行写入.这样的解释令人感觉有点玄乎,不能准确理解.
最近写了个小程序,把数据以16进制的形式存到一个文件中,当从文件中读取时,发现读取的数据不对,进行调试时,发现读取的数据与写入文件中的数据发生了错位,进行调试发现写入时并没有错误,读取时,怎么就发生错位了呢?调试了半天发现每遇到0x0A,在它前面就会多一个0x0D.
那么,是什么原因造成的呢?几经周折之后,终于发现是fopen的参数引起的.如果这么写:fp = fopen(str,"wb");可以得到正常数据,而fp = fopen(str,"w");就得不到正常数据,遇到0x0A时,就会在其前面多一个0x0D.
原来,如果有参数b,是以二进制方式打开,这种方式不会进行”回车符”和”换行符”的转换.而如果没有b,即单以”w”为参数的话,系统就把换行符0A转换为0D0A,因为windows是以0D0A为换行符的.
fgets()与fputs()
gets()与puts()一起
scanf是接受的单词 遇空格也会停止