实例讲解C语言OPEN函数语法及其应用

[摘要]  open是一个可变参数的函数实现,后面的可变参数通常表示unsigned mode,mode参数是否存在要看access的值,path是文件的路径。

open是一个非标准的低级文件I/O函数,返回的是文件的低级句柄,原型:

int open(char* path, int access, ……);

open是一个可变参数的函数实现,后面的可变参数通常表示unsigned mode,mode参数是否存在要看access的值,path是文件的路径。

access和mode的可取值通常在FCNTL.h里面定义,access的可取值如下:

#define O_RDONLY 1

#define O_WRONLY 2

#define O_RDWR 4

access还可以是以下flag及它们之间的组合而得到的性质:

#define O_CREAT 0x0100 /* create and open file */

#define O_TRUNC 0x0200 /* open with truncation */

#define O_EXCL 0x0400 /* exclusive open */

#define O_APPEND 0x0800 /* to end of file */

#define O_CHANGED 0x1000 /* user may read these bits, but */

#define O_DEVICE 0x2000 /* only RTLio functions may touch. */

#define O_TEXT 0x4000 /* CR-LF translation */

#define O_BINARY 0x8000 /* no translation */

使用O_CREAT的时候,必须指定mode参数,mode的可取值在sysstat.h里面定义,也可以是它们的组合,如下:

#define S_IREAD 0x0100 /* owner may read */

#define S_IWRITE 0x0080 /* owner may write */

open(s[i], 0x0100,0x0080);的意思是以O_CREAT和可写的方式打开s[i]中指出的文件,如果文件不存在,就创建它。返回这个文件的低级句柄。

函数原型:

int open(const char *path, int access,int mode);

作用:

以各种方式打开文件

返回值:

返回打开的文件句柄,-1 打开失败

输入参数说明:

path 要打开的文件路径和名称

access 访问模式,宏定义和含义如下: O_RDONLY 1 只读打开 O_WRONLY 2 只写打开 O_RDWR 4 读写打开

还可选择以下模式与以上3种基本模式相与:

O_CREAT 0x0100 创建一个文件并打开

O_TRUNC 0x0200 打开一个存在的文件并将文件长度设置为0,其他属性保此

O_EXCL 0x0400 未使用

O_APPEND 0x0800 追加打开文件

O_TEXT 0x4000 打开文本文件翻译CR-LF控制字符

O_BINARY 0x8000 打开二进制字符,不作CR-LF翻译

mode 该参数仅在access=O_CREAT方式下使用,其取值如下:

S_IFMT 0xF000 文件类型掩码

S_IFDIR 0x4000 目录

S_IFIFO 0x1000 FIFO 专用

S_IFCHR 0x2000 字符专用

S_IFBLK 0x3000 块专用

S_IFREG 0x8000 只为0x0000

S_IREAD 0x0100 可读

S_IWRITE 0x0080 可写

S_IEXEC 0x0040 可执行

int open(const char *path, int access,int mode);

------------------------------------------------

这个原型是错误的,由于第三个参数mode只有当access为O_CREAT的时候才有效,因此open的函数实现是一个可变参数函数,如上那样声明的话,就变成了不管access的值是多少,mode都必须给出,这是错误的。以下列举tc2.0、tc3.1、vc6.0、C++Builder和gcc中的open函数的原型:

gcc:

_CRTIMP int __cdecl _open (const char*, int, ……);

VC6.0:

_CRTIMP int __cdecl _open(const char *, int, ……);

Borland C++Builder:

int _RTLENTRY _EXPFUNC open(const char _FAR *__path, int __access,…… /*unsigned mode*/);

tc3.1:

int _Cdecl _FARFUNC open(const char _FAR *__path, int __access,…… /*unsigned mode*/);

tc2.0:

int _Cdecl open (const char *path, int access,…… /*unsigned mode*/);




免责声明:

本站系本网编辑转载,会尽可能注明出处,但不排除无法注明来源的情况,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与本网联系, 来信: liujun@soft6.com 我们将在收到邮件后第一时间删除内容!

[声明]本站文章版权归原作者所有,内容为作者个人观点,不代表本网站的观点和对其真实性负责,本站拥有对此声明的最终解释权。