Linux文件打开与关闭

可以使用库函数堆文件进行操作,同时也可以使用系统调用来进行文件操作。主要针对以下几个系统调用函数:

   open(2)、close(2)、read(2)、write(2)、lseek(2)、fcntl(2)、select(2)等需包含头文件#include、#include、#include


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

int close(int fd);

功能:关闭一个已经打开的文件

 参数:

    fd:使用open(2)函数的返回值

返回值:

    成功:0

    错误:-1,同时errno被设置

    

你可能感兴趣的:(Linux文件打开与关闭)