C语言里有一系列文件 *** 作函数。区分文本和二进制文件,需要在打开文件时设置不同的控制符mode的变量即可。
2.fopen的函数原型:FILE
*
fopen(const
char
*
path,const
char
*
mode)
fopen函数的第一个参数是文件路径,第二个参数是打开方式,有以下几种方式:
r
以只读方式打开文件,该文件必须存在。
r+
以可读写郑迟悄方式打开文件,该文件必须存在。
rb+
读写打开一个二进制文件,允许读数据。
rw+
读写打开一个文本文件,允许读和写。
w
打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
w+
打开可读写文件,若文件存在则文件长度清为零,即该旦神文件内容会消失。若文件不存在则建立该文件。
a
以喊渣附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
a+
以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。
(原来的EOF符不保留)
wb
只写打开或新建一个二进制文件;只允许写数据。
wb+
读写打开或建立一个二进制文件,允许读和写。
wt+
读写打开或着建立一个文本文件;允许读写。
at+
读写打开一个文本文件,允许读或在文本末追加数据。
ab+
读写打开一个二进制文件,允许读或在文件末追加数据。
上述的形态字符串都可以再加一个b字符,如rb、w+b或ab+等组合,加入b
字符用来告诉函数库打开的文件为二进制文件,而非纯文字文件。
问题很多:
1 不提倡直接将一个结构体以二进制的形式写入到文件,读取时也是一样的。
2 Hold结构不太清楚,如果FlightNum字段是char *类型,写入到文件的是指针的值,即“F05"字符串的首地址文件中看起来就是类似乱码的东西,这种数据是没有意义的。
如果FlightNum字段是char数组类型,ff.FlightNum="F05"这种语句就编译不过了。这种情况排除。
3 你应该知道指针之间的字符串赋值应该是调用比如memcpy这类函数实现,而且首先得为目的指针分配堆空间。由于文件内字改棚符串长度位置, 分配空间大小未知,不能保证不会出现缓冲区溢出的问题。
4 常见的写法应该是核罩则把所有字段(非字符串字段转成字符串)写入到一块缓冲区内,每个地段之间用 数据内不会出现的某个字符进行分隔,然后把整个缓冲区写入到文件, 如果有n个结构体,则重复n次。比如:
char szBuffer[1024] = {0} // 大致估计数据最大长度,如果不确定,// 可以先计算出需要的字节长度,然后new一个堆空间
int iBytes = sprintf(szBuffer, "%s\t%s\t%s\t%d\t%d\r\n"
, ff.FlightNum
, ff.LineNum
, ff.Target
, ff.Haveorder
, ff.Rest)
ofstream os("Airline.dat",ios_base::out|ios_base::binary)
os.write(szBuffer, iBytes)
5 从文件读数据,先读出一行,再按分隔符\t查找每个字段,转换字段格式。赋值到结构体的各个字段变量。
6 最好不要使用scanf获取各个字段闷裤的值,这个东西的格式容错性很差。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)