clearerr(清除文件
流的错误旗标)
相关函数feof
表头文件#include
定义函数void clearerr(FILE * stream);
函数说明clearerr()清除参数stream指定的文件流所使用的错误旗标。
返回值
fclose(关闭文件)
相关函数close,fflush,fopen,setbuf
表头文件#include
定义函数int fclose(FILE * stream);
函数说明fclose()用来关闭先前fopen()打开的文件。此动作会让缓冲区内的数据写入文件中,并释放系统所提供的文件资源。
返回值若关文件动作成功则返回0,有错误发生时则返回EOF并把错误代码存到errno。
错误代码EBADF表示参数stream非已打开的文件。
范例请参考fopen()。
fdopen(将文件描述词转为文件指针)
相关函数fopen,open,fclose
表头文件#include
定义函数FILE * fdopen(int fildes,const char * mode);
函数说明fdopen()会将参数fildes 的文件描述词,转换为对应的文件指针后返回。
参数mode 字符串则代表着文件指针的流形态,此形态必须和原先文件描述
词读写模式相同。关于mode 字符串格式请参考fopen()。
返回值转换成功时返回指向该流的文件指针。失败则返回NULL,并把错误代码存在errno中。
范例#include
main()
{
FILE * fp =fdopen(0,”w+”);
fprintf(fp,”%s\n”,”hello!”);
fclose(fp);
}
执行hello!
feof(检查文件流是否读到了文件尾)
相关函数fopen,fgetc,fgets,fread
表头文件#include
定义函数int feof(FILE * stream);
函数说明feof()用来侦测是否读取到了文件尾,尾数stream为fopen()所返回之文件指针。如果已到文件尾则返回非零值,其他情况返回0。
返回值返回非零值代表已到达文件尾。
fflush(更新缓冲区)
相关函数write,fopen,fclose,setbuf
表头文件#include
定义函数int fflush(FILE* stream);
函数说明fflush()会强迫将缓冲区内的数据写回参数stream指定的文件中。如果参数stream为NULL,fflush()会将所有打开的文件数据更新。
返回值成功返回0,失败返回EOF,错误代码存于errno中。
错误代码EBADF 参数stream 指定的文件未被打开,或打开状态为只读。其它错误代码参考write()。
fgetc(由文件中读取一个字符)
相关函数open,fread,fscanf,getc
表头文件include
定义函数nt fgetc(FILE * stream);
函数说明fgetc()从参数stream所指的文件中读取一个字符。若读到文件尾而无数据时便返回EOF。
返回值getc()会返回读取到的字符,若返回EOF则表示到了文件尾。
范例#include
main()
{
FILE *fp;
int c;
fp=fopen(“exist”,”r”);
while((c=fgetc(fp))!=EOF)
printf(“%c”,c);
fclose(fp);
}
fgets(由文件中读取一字符串)
相关函数open,fread,fscanf,getc
表头文件include
定义函数har * fgets(char * s,int size,FILE * stream);
函数说明fgets()用来从参数stream所指的文件内读入字符并存到参数s所指的内存空间,直到出现换行字符、读到文件尾或是已读了size-1个字符为止,最
后会加上NULL作为字符串结束。
返回值gets()若成功则返回s指针,返回NULL则表示有错误发生。
范例#include
main()
{
char s[80];
fputs(fgets(s,80,stdin),stdout);
}
执行this is a test /*输入*/
this is a test /*输出*/
fileno(返回文件流所使用的文件描述词)
相关函数open,fopen
表头文件#include
定义函数int fileno(FILE * stream);
函数说明fileno()用来取得参数stream指定的文件流所使用的文件描述词。
返回值返回文件描述词。
范例#include
main()
{
FILE * fp;
int fd;
fp=fopen(“/etc/passwd”,”r”);
fd=fileno(fp);
printf(“fd=%d\n”,fd);
fclose(fp);
}
执行fd=3
fopen(打开文件)
相关函数open,fclose
表头文件#include
定义函数FILE * fopen(const char * path,const char * mode);
函数说明参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态。
mode有下列几种形态字符串:
r 打开只读文件,该文件必须存在。
r+ 打开可读写的文件,该文件必须存在。
w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若
文件不存在则建立该文件。
w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。
若文件不存在则建立该文件。
a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件
存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。
a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果
文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。
上述的形态字符串都可以再加一个b字符,如rb、w+b或ab+等组合,加
入b 字符用来告诉函数库打开的文件为二进制文件,而非纯文字文件。不
过在POSIX系统,包含Linux都会忽略该字符。由fopen()所建立的新文件
会具有S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH(0666)权限,
此文件权限也会参考umask值。
返回值文件顺利打开后,指向该流的文件指针就会被返回。若果文件打开失败则返回NULL,并把错误代码存在errno 中。
附加说明一般而言,开文件后会作一些文件读取或写入的动作,若开文件失败,接下来的读写动作也无法顺利进行,所以在fopen()后请作错误判断及处理。
范例#include
main()
{
FILE * fp;
fp=fopen(“noexist”,”a+”);
if(fp= =NULL) return;
fclose(fp);
}
fputc(将一指定字符写入文件流中)
相关函数fopen,fwrite,fscanf,putc
表头文件#include
定义函数int fputc(int c,FILE * stream);
函数说明fputc 会将参数c 转为unsigned char 后写入参数stream 指定的文件中。
返回值fputc()会返回写入成功的字符,即参数c。若返回EOF则代表写入失败。
范例#include
main()
{
FILE * fp;
char a[26]=”abcdefghijklmnopqrstuvwxyz”;
int i;
fp= fop en(“noexist”,”w”);
for(i=0;i<26;i++)
fputc(a[i],fp);
fclose(fp);
}
fputs(将一指定的字符串写入文件内)
相关函数fopen,fwrite,fscanf,fputc,putc
表头文件#include
定义函数int fputs(const char * s,FILE * stream);
函数说明fputs()用来将参数s所指的字符串写入到参数stream所指的文件内。
返回值若成功则返回写出的字符个数,返回EOF则表示有错误发生。
范例请参考fgets()。
fread(从文件流读取数据)
相关函数fopen,fwrite,fseek,fscanf
表头文件#include
定义函数size_t fread(void * ptr,size_t size,size_t nmemb,FILE * stream);函数说明fread()用来从文件流中读取数据。参数stream为已打开的文件指针,参数ptr 指向欲存放读取进来的数据空间,读取的字符数以参数size*nmemb来
决定。Fread()会返回实际读取到的nmemb数目,如果此值比参数nmemb 来
得小,则代表可能读到了文件尾或有错误发生,这时必须用feof()或
ferror()来决定发生什么情况。
返回值返回实际读取到的nmemb数目。
附加说明
范例#include
本文档为【clearerr】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑,
图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。