fopen fclose fread fwrite fseek ftell rewind带缓冲的文件操作函数:
fopen:
看一下原型:
FILE *fopen(const char *path, const char *mode);
FILE *fdopen(int fd, const char *mode);
FILE *freopen(const char *path, const char *mode, FILE *stream);
参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态。
mode有下列几种形态字符串:
r 打开只读文件,该文件必须存在。
r+ 打开可读写的文件,该文件必须存在。
w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。
a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。
上述的形态字符串都可以再加一个b字符,如rb、w+b或ab+等组合,加入b 字符用来告诉函数库打开的文件为二进制文件,而非纯文字文件。不过在POSIX系统,包含Linux都会忽略该字符。在linux系统上,man手册里面没有说明b字符。
由fopen()所建立的新文件会具有S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH(0666)权限,但是他需要参考umask值,例如umask = 0002 那么创建的文件的权限就是:0664
返回值:
文件顺利打开后,指向该流的文件fp指针就会被返回。若果文件打开失败则返回NULL,并把错误代码存在errno 中。
fclose:
int fclose(FILE *stream);
fread fwrite:
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
size_t fwrite(const void *ptr, size_t size, size_t nmemb,
FILE *stream);
ptr表示读的数据放进的buff
size:要读写的每个项的字节数,nmemb表示要读少个项
例如:fread (buff, sizeof (char), 1024, fp);
表示要读1024个项,每个项是1个字节的。同理fwrite
fseek:功能是移动文件位置指针
int fseek(FILE *stream, long offset, int whence);
whence: SEEK_SET, SEEK_CUR, SEEK_END,
注意使用的正确形式。例如 SEEK_SET, offset = -5, 那么读到的是什么?
实际测试是第一个字符,但是现在fseek的返回值,也就是文件偏移是-5了。
ftell:用于得到文件位置指针当前位置相对于文件首的偏移字节数
long ftell(FILE *stream);
ftell和fseek一起使用,可以得到文件的大小
例如:
fseek(fp, 0, SEEK_END)
len = ftell(fp);
就可以得到文件的大小,是多少bytes了。单位是bytes。
rewind:
void rewind(FILE *stream);
rewind的函数就是把文件指针从你现在读取的位置,重新回到文件开头
perror:
void perror(const char *s);
如果要使用errno,需要包含:#include <errno.h>头文件,errno我们看其实没有太大的用,我们使用perror把errno对应的字符串形式打印出来就可以了。
perror的功能是:打印出errno对应的错误的字符串形式。
总结:
缓冲IO一般用于文件操作,不带缓冲的IO一般用于设备节点的操作。
部分素材来源于网络,如有侵权,请联系作者删除,谢谢!