操作系统实验涉及的一些文件操作基础知识。
目录
一、打开文件
打开文件操作:
使用系统调用函数open(),该函数的作用是建立一个文件描述符,其他的函数可以通过文件描述符对指定文件进行读取与写入的操作。
打开文件的一般形式是:
open(文件路径, 标志);
函数的返回值是文件描述符,如果打开文件成功返回一个正整数,否则返回-1。
标志是用于指定打开文件操作模式的枚举常量,有主标志和副标志。主标志是互斥的,使用其中一种则不能再使用另外一种。除了主标志以外,还有副标志可与它们配合使用,副标志可同时使用多个,使用时在主标志和副标志之间加入按位与(|)运算符。
主标志
说 明
主标志
说 明
O_RDONLY
以只读方式打开文件
O_RDWR
以可读写方式打开文件
O_WRONLY
以只写方式打开文件
副标志
说 明
O_APPEND
读写文件从文件尾部开始移动,所写入
的数据追加到文件尾
O_TRUNC
若文件存在并且以可写的方式打开时,
此标志会将文件长度清为0,而原来存于
该文件的资料也会消失
O_CREAT
若路径中的文件不存在则自动建立该文件
O_EXCL
如果与O_CREAT同时设置,此指令会去检
查文件是否存在,文件若不存在则建立该文
件,否则将导致打开文件错误。此外,若
O_CREAT与O_EXCL同时设置,并且将要
打开的文件为符号连接,则将导致打开文件失败
二、新建文件操作
方法一:在打开文件的基础上,加上副标志O_CREAT实现文件不存在时创建文件。
创建文件的同时可设置文件的权限,这时函数需要增加一组实际参数,形式为:
open(文件路径, 标志, 权限标志);
表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
所有者拥有
执行权限
群组拥有执行权限
其他用户拥
有执行权限
方法二:使用create()函数
该函数的一般形式是:
creat(路径, umask);
当文件被成功创建函数的返回值为0,否则为-1。
三、关闭文件操作
当文件不需要使用了,则可以使用close()函数关闭文件。
关闭文件的一般形式为:
close(文件描述符);
如果关闭文件成功,close()函数的返回0,否则返回-1。
四、头文件
- #include <sys/types.h> // 提供mode_t类型
- #include <sys/stat.h> // 提供open()函数的符号
- #include <unistd.h> // 提供close()函数