可以使用库函数堆文件进行操作,同时也可以使用系统调用来进行文件操作。主要针对以下几个系统调用函数:
open(2)、close(2)、read(2)、write(2)、lseek(2)、fcntl(2)、select(2)等需包含头文件#include<sys/ypes.h>、#include<sys/stat.h>、#include<fcntl.h>。
open(2)
int open(cosnt char *pathname,int flags,...)//...代表可变参数,取决于flags。
int open(cosnt char *pathname,int flags);
int open(cosnt char *pathname,int flags,mode_t mode);
功能:
打开一个文件或设备
参数:
pathname:指定文件路径的名称
flags:
O_RDONLY:只读方式打开
O_WRONLY:只写方式打开
O_RDWR:可读可写方式打开
以上参数3选一,根据需要按位或以下文件创建标志和文件状态标志选项。
O_CREAT:如果文件不存在,就创建一个新文件,并用第三个参数为其设置权限。
O_EXCL:如果使用O_CREAT时文件存在,则可返回错误消息,这一参数可测试文件是否存在。
O_NOCTTY:使用本参数,如果文件为终端,那么终端不可以作为调用open系统调用的那个进程控制终端。
O_TRUNC:如果文件存在,并且一只读或者只写方式成功打开,那么会先全部删除文件中原有的数据。
O_APPEND:以添加方式打开文件,打开文件的同时,文件指针指向文件的末尾。
mode:
被打开文件的存取权限,当使用O_CREAT选项时,此参数必须被提供。权限的有效性是提供权限和umask的运算结果。
使用ls -l选项,通过首字符可以辨识文件类型
- 普通文件
d 文件夹文件
b 块设备文件
c 字符设备文件
s socket文件
l 软链接文件
p 管道文件
文件类型后面分为三组,代表不同的属性
rw-rw-r--,每三个字符一组,分别代表读写执行权限,称为ugo权限,从左至右分别为文件的所有者、组和其他人。所谓的 ugo 就是指 user(也称为 owner)、group 和 other 三个单词的首字母组合。
文件的所有者
文件的所有者一般是创建该文件的用户,对该文件具有完全的权限。在一台允许多个用户访问的 Linux 主机上,可以通过文件的所有者来区分一个文件属于某个用户。当然,一个用户也无权查看或更改其它用户的文件。
文件所属的组
假如有几个用户合作开发同一个项目,如果每个用户只能查看和修改自己创建的文件就太不方便了,也就谈不上什么合作了。所以需要一个机制允许一个用户查看和修改其它用户的文件,此时就用到组的概念的。我们可以创建一个组,然后把需要合作的用户都添加都这个组中。在设置文件的访问权限时,允许这个组中的用户对该文件进行读取和修改。
其他人
如果我想把一个文件共享给系统中的所有用户该怎么办?通过组的方式显然是不合适的,因为需要把系统中的所有用户都添加到一个组中。并且系统中添加了新用户该怎么办,每添加一个新用户就把他添加到这个组中吗?这个问题可以通过其他人的概念解决。在设置文件的访问权限时,允许其他人户对该文件进行读取和修改。
linux修改文件读写执行权限命令chmod见前面的笔记
文件或文件夹创建或打开有默认权限0666,通过设置umask权限掩码来设置创建文件或者文件夹的最终默认权限,umask+权限代码掩码即可设置umask,最终权限=mode&(~umask)
文件描述符
0 STDIN_FILENO
1 STDOUT_FILENO
2 STDERR_FILENO
close(2)
#include<unistd.h>
int close(int fd);
功能:关闭一个已经打开的文件
参数:
fd:使用open(2)函数的返回值
返回值:
成功:0
错误:-1,同时errno被设置
网友评论