// 要判断一下是否打开文件失败,失败fp是NULL指针,继续 *** 作是非法的。
if (NULL == fp)
{
printf("打开文件失败! 错误码:%d,错误原因:%s\r\n", errno, strerrno(errno))
return -1
}
如果fopen打开失败返回值为NULL在windows环境中能在<stddef.h>找到
#ifdef __cplusplus
#define NULL ((void *)0)
#else
#define NULL 0
#endif
NULL 被定义为 0
也就是A选0
但是这并不代表C语言中NULL一定是0,NULL是代表一个绝对不存在的地址,但不一定是0
比如一个系统可以选取一个远大于所有内存地址的值来代表NULL
所以,仅从C语言标准来看,此题出得有问题(就是没有正确答案)
是,你可以给我扯,绝大多数主流 *** 作系统都是NULL为0,但这是C语言
标准就是标准,没有就是没有
①文件不存在;②文件名错误,打开文件的名字应该写成"c:\\file.txt",而不是"c:\file.txt";
③代码错误;
fopen函数用于打开文件并获取文件的指针,以便对文件进行 *** 作。
函数原型:FILE
*
fopen(const
char
*
path,const
char
*
mode)
参数:path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态。
mode有下列几种形态字符串:
r
以只读方式打开文件,该文件必须存在。
r+
以可读写方式打开文件,该文件必须存在。
rb+
读写打开一个二进制文件,允许读写数据,文件必须存在。
w
打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
w+
打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
a
以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
a+
以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。
(原来的EOF符不保留)
wb
只写打开或新建一个二进制文件;只允许写数据。
wb+
读写打开或建立一个二进制文件,允许读和写。
ab+
读写打开一个二进制文件,允许读或在文件末追加数据。
上述的形态字符串都可以再加一个b字符,如rb、w+b或ab+等组合,加入b
字符用来告诉函数库以二进制模式打开文件。如果不加b,表示默认加了t,即rt,wt,其中t表示以文本模式打开文件。由fopen()所建立的新文件会具有S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH(0666)权限,此文件权限也会参考umask值。
有些C编译系统可能不完全提供所有这些功能,有的C版本不用"r+","w+","a+",而用"rw","wr","ar"等,读者注意所用系统的规定。
返回值:
文件顺利打开后,指向该流的文件指针就会被返回。如果文件打开失败则返回NULL,并把错误代码存在errno中。
一般而言,打开文件后会做一些文件读取或写入的动作,若打开文件失败,接下来的读写动作也无法顺利进行,所以一般在fopen()后作错误判断及处理。
示例:以只读方式打开文件
#include<stdio.h>
#define
F_PATH
"d:\\myfile\\file.dat"
int
main(void)
{
FILE*fp=NULL//需要注意
fp=fopen(F_PATH,"r")
if(NULL==fp)
{
return
-1//要返回错误代码
}
fclose(fp)
fp=NULL//需要指向空,否则会指向原打开文件地址
return
0
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)