UNIX文件mode_t详解
打开文件、新建文件和关闭文件操作
打开文件操作使用系统调用函数open(),该函数的作用是建立一个文件描述符,其他的函数可以通过文件描述符对指定文件进行读取与写入的操作。打开文件的一般形式是:
函数的返回值是文件描述符,如果打开文件成功返回一个正整数,否则返回-1。标志是用于指定打开文件操作模式的枚举常量,主标志如表13.1所示。
表13.1 打开文件操作的主标志
参 数
说 明
参 数
说 明
O_RDONLY
以只读方式打开文件
O_RDWR
以可读写方式打开文件
O_WRONLY
以只写方式打开文件
主标志是互斥的,使用其中一种则不能再使用另外一种。除了主标志以外,还有副标志可与它们配合使用,副标志可同时使用多个,使用时在主标志和副标志之间加入按位与(|)运算符,如表13.2所示。
表13.2 打开文件操作的副标志
参 数
说 明
O_APPEND
读写文件从文件尾部开始移动,所写入
的数据追加到文件尾
O_TRUNC
若文件存在并且以可写的方式打开时,
此标志会将文件长度清为0,而原来存于
该文件的资料也会消失
O_CREAT
若路径中的文件不存在则自动建立该文件
O_EXCL
如果与O_CREAT同时设置,此指令会去检
查文件是否存在,文件若不存在则建立该文
件,否则将导致打开文件错误。此外,若
O_CREAT与O_EXCL同时设置,并且将要
打开的文件为符号连接,则将导致打开文件失败
新建文件操作是在打开文件操作的函数上加入O_CREAT副标志实现的。当路径中的文件不存在时,则创建一个新文件。创建新文件的同时可设置文件的权限,这时函数需要增加一组实际参数,形式为:
文件权限标志如表13.3所示。
表13.3 文件权限标志
参 数
说 明
参 数
说 明
S_IRUSR
所有者拥有
读权限
S_IXGRP
群组拥有执
行权限
S_IWUSR
所有者拥有
写权限
S_IROTH
其他用户拥
有读权限
S_IXUSR
所有者拥有
执行权限
S_IWOTH
其他用户拥
有写权限
S_IRGRP
群组拥有读权限
S_IXOTH
其他用户拥
有执行权限
S_IWGRP
群组拥有写权限
文件权限标志也可以使用加权数字表示,这组数字被称为umask变量,它的类型是mode_t,是一个无符号八进制数。umask变量的定义方法如表13.4所示。umask变量由3位数字组成,数字的每一位代表一类权限。用户所获得的权限是加权数值的总和。例如764表示所有者拥有读、写和执行权限,群组拥有读和写权限,其他用户拥有读权限。
表13.4 umask变量表示方法
加 权 数 值
第1位
第2位
第3位
4
所有者拥有
读权限
群组拥有读权限
其他用户拥
有读权限
2
所有者拥有
写权限
群组拥有写权限
其他用户拥
有写权限
1
所有者拥有
执行权限
群组拥有执行权限
其他用户拥
有执行权限
新建文件的另一个函数是creat(),该函数的一般形式是:
当文件被成功创建函数的返回值为0,否则为-1。当文件不需要使用了,则可以使用close()函数关闭文件。关闭文件的一般形式为:close(文件描述符),如果关闭文件成功,close()函数的返回0,否则返回-1。
下例将演示打开文件、新建文件和关闭文件这3种操作。程序的逻辑为:指定一个路径,如果该文件存在,输出提示信息,关闭该文件;如果该文件不存在,则新建文件并设置文件属性,输出提示信息,然后关闭该文件。完整的代码如下:
注:这篇文章来自博客园一博主的贡献,感谢博主的分享