#include <stdio.h>
c库中的标准io;带缓冲区,减少系统调用的次数,提高访问效率;
FILE *fopen(const char *path, const char *mode);
参数:
path 文件名,若不包含路径,则默认在当前程序的目录
mode,打开方式
r/rb/r+/r+b 以只读/读写方式打开文件,文件必须存在
w/wb/w+/w+b 以只写/读写方式打开文件,若文件存在,则清空,若文件不存在则创建,这里的读只能读打开新写入的数据
a/a+/a+b 以追加/追加写的方式打开文件,若文件存在,则追加,若文件不存在则创建
以上的b参数是表示以二进制的形式打开文件,在linux忽略,也就是r跟rb的效果是一样的
新建文件的访问权限,默认是0666(八进制666)
还受系统中默认的权限掩码umask(022)影响,所以文件的最终权限为默认权限&掩码的取反
0666 & ~umask
如果不受系统掩码影响,可以设置系统掩码为0,设置后只影响本程序,其它程序不受影响
int fclose(FILE *stream);
参数:需关闭的流指针
返回值,关闭成功返回0,失败返回EOF,并设置errno
流关闭时自动刷新缓冲区的数据到实际的文件里并释放缓冲区
当一个程序正常关闭时,所有打开的流都会被关闭
思考题:
程序中能够打开的文件或流有限制,如何测试?
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#define PATH "./temp"
int main()
{
FILE *fp;
int count=0;
char buf[128]={0};
while(1)
{
snprintf(buf,sizeof(buf),"%s/%d.txt",PATH,count);
fp = fopen(buf,"w+");
if(fp != NULL)
{
count ++;
}else
{
perror("fopen");
break;
}
}
printf("total:%d\n",count);
if(fp != NULL)
fclose(fp);
return 0;
}
运行结果:
fopen: Too many open files
total:1021
结论:一个进程中能打开流的个数为1021+stdin+stdout+stderr=1024