分类: LINUX
2015-08-24 14:30:38
函数:(1) FILE *fopen(const char *pathname,const char *type);
(2) FILE *freopen(const char *pathname,const char *type, FILE *fp);
(3) FILE *fdopen(int filedes,const char *type);
头文件:stdio.h
说明:
fopen函数用来打开一个特定的文件;
freopen用来在一个特定的流上打开一个特定的文件,当调用freopen时,首先关闭fp流,然后重新使用这个FILE结构指针fp打开pathname所代表的文件,此函数常用来对标准输入、标准输出、标准错误输出等预定义的流进行重定向。
fdopen用于将一个流和某一个已打开的特定文件相对应,filedes表示此文件的描述符,当只有type所定义的模式和filedes所表示的文件的打开模式相同时,调用才能成功。此函数多用于建立某一流和无法用于I/O操作函数的文件之间的关联,特别是管道文件和网络通信管道。
Type说明如下:
type |
文件类型 |
是否新建 |
是否清空 |
可读 |
可写 |
读写位置 |
r |
文本文件 |
NO |
NO |
YES |
NO |
文件开头 |
r+ |
文本文件 |
NO |
NO |
YES |
YES |
文件开头 |
w |
文本文件 |
YES |
YES |
NO |
YES |
文件开头 |
w+ |
文本文件 |
YES |
YES |
YES |
YES |
文件开头 |
a |
文本文件 |
NO |
NO |
NO |
YES |
文件结尾 |
a+ |
文本文件 |
YES |
NO |
YES |
YES |
文件结尾 |
rb |
二进制文件 |
NO |
NO |
YES |
NO |
文件开头 |
r+b或rb+ |
二进制文件 |
NO |
NO |
YES |
YES |
文件开头 |
wb |
二进制文件 |
YES |
YES |
NO |
YES |
文件开头 |
w+b或wb+ |
二进制文件 |
YES |
YES |
YES |
YES |
文件开头 |
ab |
二进制文件 |
NO |
NO |
NO |
YES |
文件结尾 |
a+b或ab+ |
二进制文件 |
YES |
NO |
YES |
YES |
文件结尾 |
函数:int fclose(FILE *fp);
头文件:stdio.h
说明:调用成功返回0,调用失败返回-1,并设置errno的值,如果程序结束前没有执行流动关闭操作,有可能会造成写入的数据停留在缓冲区里没有保存到文件中,从而造成数据的丢失。
全缓冲区:该类型缓冲区要求填满整个缓冲区后才进行I/O操作,对于磁盘文件常使用全缓冲区访问。
行缓冲区:在该种模式下,当在输入和输出中遇到换行符时,标准I/O库执行I/O系统调用操作。当流涉及到一个终端时,使用行缓冲区。因为标准I/O库收集的每行的缓冲区长度为固定的,只要填满缓冲区,即使还没有遇到换行符,也将执行I/O系统调用。默认行缓冲区大小为128字节。
无缓冲区:标准I/O库不对字符进行缓存,如果用标准I/O函数写若干字符到不带缓冲区的流中,则相当于用write系统调用函数将这些字符写至相关联动打开文件。标准错误流通常不带缓冲区,从而能使错误信息尽快的显示出来。
函数:int setbuf(FILE *fp,char *buf);
Int setbuffer(FILE *fp,char *buf,size_t size);
Int setlinebuf(FILE *buf);
Int setvbuf(FILE *fp,char *buf,int mode,size_t size);
头文件:stdio.h
说明:
l setbuf函数用于将缓冲区设置为全缓冲或无缓冲,buf为指向缓冲区的指针。当buf指向一个真实缓冲区地址时,将缓冲区设置为全缓冲,大小有常数BUFSIZE指定,当buf为NULL时,则设定为无缓冲,此函数一般用作激活或禁止缓冲区的开关。
l setbuffer函数与setbuf类似,区别在于可以有程序员设定缓冲区大小size。
l setlinebuf用于将缓冲区设定为行缓冲区。
l setvbuf的mode参数可以指定缓冲区类型,即: _IOFBF(全缓冲类型)、_IOLBF(行缓冲类型)、_IONBF(无缓冲类型 )。
一般而言需要在流打开但没有执行其他操作时候设定其类型,因为改变缓冲区类型会对所指向的操作参数影响。
函数:int fflush(FILE *fp);
头文件:stdio.h
说明:用于将缓冲区尚未写入文件的数据强制性的保存到文件中。
函数:size_t fread(void *ptr,size_t size,size_t nmemb,FILE *fp);
头文件:stdio.h
说明:ptr为存储要读取数据的缓冲区,size 为读取记录的大小,nmemb是所读取记录的个数,fp为所要读取的流的文件FILE指针,其返回值为实际读取的记录个数。
函数:size_t fwrite(const void *ptr,size_t size,size_t nmemb,FILE *fb);
头文件:stdio.h
说明:ptr为指向存放要输入数据的缓冲区指针,size为写入记录的大小,nmemb为所写记录的个数,fp为所要写入的流的文件FILE指针,其返回值为实际写入的记录个数。
函数:(1)int feof(FILE *fp); (2)ferror(FILE *fp);
头文件:stdio.h
说明:feof函数用来检测是否读到文件的结尾,当没有访问到文件的结尾时,返回为0,当访问到文件的结尾时,返回为1,只有执行读操作时候才对文件结束标志进行操作;ferror函数用来检测是否出现了读写错误,当访问正常接收时候,函数返回值为0,当访问非正常结束时,返回值为非0,并设置errno的值。此时errno的值为错误发生时由读写函数本身所设定的。
函数:void clearer(FILE *fp);
头文件:stdio.h
说明:该函数当文件发生超过文件末尾读取或读写错误时来重置结束标志和错误标志。
函数: int rewind(FILE *stream);
头文件: stdio.h
说明: 将文件指针重新指向一个流的开头
函数: int fgetpos(FILE *stream);
头文件:stdio.h
说明: 取得当前文件的句柄
函数 :
(1) int printf(const *format,…);
(2) int fprintf(FILE *fp,const char *format,…);
(3) int sprintf(char *str,const char *format,…);
(4) int snprintf(char *str,size_t size,const format,…);
(5) int vprintf(const *format,va_list ap);
(6) int vfprintf(FILE *fp,const char *format, va_list ap);
(7) int vsprintf(char *str,const char *format, va_list ap);
(8) int vsnprintf(char *str,size_t size,const format, va_list ap);
头文件:stdio.h
说明:略
函数:
(1) int scanf(const char *format,…);
(2) int fscanf(FILE *fp,const char *format,…);
(3) int vsscanf(char *str,const char *format,…);
(4) int vscanf(const char *format, va_list ap);
(5) int vfscanf(FILE *fp,const char *format, va_list ap);
(6) int vsscanf(char *str,const char *format, va_list ap);
头文件:stdio.h
说明:略
函数:
(1)int fputc(int c,FILE *fp);
(2)int putc(int c,FILE *fp);
(3)int putchar(int c);
头文件:stdio.h
说明:参数c表示要输出的字符;
函数:int ungetc(int c,FILE *fp);
头文件:stdio.h
说明:用于将读入的字符再推回流中。
函数:
(4)int fgetc(FILE *fp);
(5)int getc(FILE *fp);
(6)int getchar(void);
头文件:stdio.h
说明:fgetc和getc的区别在于getc的参数是不能有副作用的表达式,而fgetc可以,getc比调用fgetc消耗时间少;getchar相当于以stdin为参数的getc函数。
函数:(1) int fputs(const char *str,FILE *fp);
(2)int puts(const char *str);
头文件:stdio.h
说明:略
函数:(1) char *fgets(char *str,int size, FILE *fp);
(2) char *gets(char *str);
头文件:stdio.h
说明:略
临时文件是指那些在程序运行期间存在并使用,而当程序运行完之后就删除的文件,临时文件的操作都是在基于流的基础上进行的。
函数:(1) char * tmpnam(char *str);
(2) char *tempnam(const char *directory,const char *prefix);
(3) FILE *tmpfile(void);
头文件:stdio.h
说明:
tmpnam作用是生成一个有效的文件名,该文件名不同于任何一个已经存在的文件名,str指向用于保存新生成文件名的缓冲区。该缓冲区长度要大于等于L_tmpnam,该常数在stdio库中定义。调用成功返回该缓冲区的指针,如果参数为NULL,则在静态缓冲区中存放生成的文件名,但是要再次调用该函数时将改变这一区域中的文件名,因此,,如果要保存文件名的话,必须要开辟相应的缓冲区来存放文件名。当调用失败是返回空指针。此外,tmpnam调用次数有所限制,必须小于等于TMP_MAX的值,该值在stdio库中定义。Tmpnam生产的文件名不能指定文件的路径和前缀,通常位于/tmp或/var/tmp目录下。
Tempnam函数与tmpnam的区别在于它可以指定临时文件所在的目录。Directory可以指定文件的路径名,路径名的选取一般如下:如果已定义了环境变量TMPDIR,则使用TMPDIR,如果没有定义,directory不为空,则以directory所指向的缓冲区来做路径名。如果TMPDIR未定义,切directory为NULL,则以P_tmpdir为路径名,P_tmpdir由stdio定义,其优先级如下:
TMP>directory>P_tmpdir
Prefix为指定文件的前缀,当prefix不为NULL时,其所指向的缓冲区存放的字符串指定的前缀。其生成的文件名放在一块动态存储区中,有该函数调用malloc来分配,函数返回之西那个存放文件名的缓冲区指针,该文件使用完毕后,需要调用free来释放。
tmpfile用于打开一个临时文件,该函数将创建一个临时二进制文件,该文件会在程序结束后自动删除,调用tmpfile生成临时文件时,它首先会调用函数tmpnam生产临时文件的文件名,然后创建这一文件,在程序结束时,系统调用ulink函数,文件将会删除