fopen的函数原型为: FILE *fopen(const char *filename, const char *mode);其功能是使用给定的模式 mode 打开 filename 所指向的文件。文件顺利打开后,指向该流的文件指针就会被返回。如果文件打开失败则返回 NULL,并把错误代码存在 error 中。该函数位于C 标准库中。1

fopen函数语法函数原型FILE *fopen(const char *filename, const char *mode);

参数filename-- 这是 C 字符串,包含了要打开的文件名称。

mode-- 这是 C 字符串,包含了文件访问模式。

功能使用给定的模式mode打开filename所指向的文件。

返回值文件顺利打开后,指向该流的文件指针就会被返回。如果文件打开失败则返回 NULL,并把错误代码存在error中。

一般而言,打开文件后会做一些文件读取或写入的动作,若打开文件失败,接下来的读写动作也无法顺利进行,所以一般在 fopen() 后作错误判断及处理。1

参数说明参数mode字符串包含了文件访问模式,欲打开的文件路径及文件名,参数 mode 字符串则代表着流形态。

mode 有下列几种形态字符串:

|| ||

以 x 结尾的模式为独占模式,文件已存在或者无法创建(一般是路径不正确)都会导致 fopen 失败。文件以操作系统支持的独占模式打开。

上述的形态字符串都可以再加一个 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"等,读者注意所用系统的规定。

二进制****和文本模式的区别

1、在Windows系统中,文本模式下,文件以"\r\n"代表换行。若以文本模式打开文件,并用 fputs 等函数写入换行符"\n"时,函数会自动在"\n"前面加上"\r"。即实际写入文件的是"\r\n"。

2、在类 Unix/Linux 系统中文本模式下,文件以"\n"代表换行。所以 Linux 系统中在文本模式和二进制模式下并无区别。1

打开方式总结:

各种打开方式主要有三个方面的区别:

1、打开是否为二进制文件,用“b”标识。

2、读写的方式,有以下几种:只读、只写、读写、追加只写、追加读写这几种方式。

3、对文件是否必 须存在、以及存在时是清空还是追加会有不同的响应。具体判断如下图。

程序示例示例一

#include #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;}示例二

#include #include /* 为了使用exit() */int main(void){ int i = 0; /* 用于 putchar & getc 的数据接收 */ char ch = ' '; FILE *fp = NULL; char fname[50]; /* 用于存放文件名 */ printf("输入文件名:"); scanf("%s", fname); fp = fopen(fname, "r"); /* 只供读取 */ if (NULL == fp) /* 如果失败了 */ { printf("错误!"); exit(1); /* 中止程序 */ } while ((ch = getc(fp)) != EOF) { putchar(ch); i ++; } fclose(fp); /* 关闭文件 */ fp = NULL; /* 需要指向空,否则会指向原打开文件地址 */ return 0;}注意!初学者往往会犯一个错误,即在输入文件名时不加后缀名,请注意加上!

示例三

#include FILE *stream, *stream2;int main(void){ int numclosed; /* Open for read (will fail if file "crt_fopen.c" does not exist) */ if ((stream = fopen("crt_fopen.c", "r")) == NULL) /* C4996 */ //Note: fopen is deprecated; consider using fopen_s instead printf("The file crt\_fopen.c' was not opened\\n"); else printf("The file crt_fopen.c' was opened\n"); /* Open for write */ if ((stream2 = fopen("data2", "w+")) == NULL) /* C4996 */ printf("The file data2' was not opened\\n"); else printf("The file data2' was opened\n"); /* Closes tream if it is not NULL */ if (stream) { if (fclose(stream)) { printf("The file `crt_fopen.c' was not closed\n"); } } /* All other files are closed: */ numclosed = _fcloseall(); printf("Number of files closed by _fcloseall: %u\n", numclosed);}示例四

Linux 下的程序示例。

在 / opt / C_lanuage / fopen_fread 新建两个文本,main.c 和 tmp.txt

tmp.txt:

I Love You Linux----Red Hat Enterprise----梦剧场的记忆

main.c 程序:

#include int main(void){ FILE *fp = NULL; char tmp[100]; fp = fopen("/opt/C_lanuage/fopen_fread/tmp.txt", "r"); if (NULL == fp) { printf("File open fail!\n"); return -1; } fread(tmp, 1, 100, fp); printf("%s\n", tmp); fclose(fp); fp = NULL; return 0;}编译加执行

[root@localhost fopen_fread]# gcc - g main.c - o main

[root@localhost fopen_fread]# . / main

I Love You Linux----Red Hat Enterprise----梦剧场的记忆

在文件操作时,需要注意以下几点问题:

1、在定义文件指针时,要将文件指针指向空;如 FILE *fp = NULL;

2、在文件操作完成后,需要将文件关闭,一定要注意,否则会造成文件所占用内存泄漏和在下次访问文件时出现问题。

3、文件关闭后,需要将文件指针指向空,这样做会防止出现游离指针,而对整个工程造成不必要的麻烦;如:fp = NULL;

拓展延伸—fopen在PHP中函数原型resource fopen ( string filename, string mode, [ bool use_include_path, [resource zcontext]] )

功能fopen() 函数打开一个文件或 URL。

如果 fopen() 失败,它将返回 FALSE 并附带错误信息。您可以通过在函数名前面添加一个 '@' 来隐藏错误输出。

应用说明fopen() 将 filename 指定的名字资源绑定到一个流上。如果 filename 是 "scheme://..." 的格式,则被当成一个 URL,PHP 将搜索协议处理器(也被称为封装协议)来处理此模式。如果该协议尚未注册封装协议,PHP 将发出一条消息来帮助检查脚本中潜在的问题并将 filename 当成一个普通的文件名继续执行下去。

如果 PHP 认为 filename 指定的是一个本地文件,将尝试在该文件上打开一个流。该文件必须是 PHP 可以访问的,因此需要确认文件访问权限允许该访问。如果激活了 安全模式 或者 open_basedir 则会应用进一步的限制。2

应用示例拓展延伸—MATLAB函数在matlab中,fopen也是一个打开文件的函数。在matlab的命令窗口中输入doc fopen或者help fopen就可以获得该函数的帮助信息。3

调用格式fileID = fopen(filename)

fileID = fopen(filename, permission)

fileID = fopen(filename, permission, machineformat)

fileID = fopen(filename, permission, machineformat, encoding)

[fileID, message]= fopen(filename, ...)

fIDs = fopen('all')

[filename, permission, machineformat, encoding]= fopen(fileID)

各种调用格式详情请参阅MATLAB帮助文档。

程序示例% MATLAB: fopen()函数的使用clcfileID = fopen('Test.txt', 'w');if fileID == -1disp('fopen failed.');return;elsedisp('fopen succeed.');endStr = 'It is just a test. By mayadong7349';fprintf(fileID, '%s', Str);% Caution:disp('Now, I''d like to type the file.');type('Test.txt');fclose(fileID);程序首先向文件写入字符串,然后通过type打印在屏幕上。

这里需要注意的是,如果字符串内有单撇号(')要用两个单撇号表示一个单撇号。

在Oracle中

Oracle提供的文件操作包UTL_FILE包中的UTL_FILE.FOPEN负责打开一个文件。

UTL_FILE.FOPEN(location in varchar2, filename in varchar2, open_mode in varchar2) return FILE_TYPE;

Location 是路径参数,

FILENAME 是文件名,

OPEN_MODE是打开模式,'R'是读文本,'W'是写文本,'A'是附加文本,参数不分大小写,如果指定'A'但是文件不存在,它会用'W'先创建出来,'W'有覆盖的功能;

其中的location并不能简单的指定为'D:\temp'等路径,要建立一个DIRECTORY变量并付给权限(必须以DBA身份登录):

create or replace directory D_OUTPUT as 'D:\TEMP';

grant read,write on directory D_OUTPUT to testdb;

GRANT EXECUTE ON utl_file TO testdb;

之后就可以用UTL_FILE包建立文件了 :

V_FILE UTL_FILE.FILE_TYPE;

V_FILE := UTL_FILE.FOPEN('D_OUTPUT', 'Data.txt', 'w');

本词条内容贡献者为:

徐恒山 - 讲师 - 西北农林科技大学