Linux下的umask函数

    技术2022-07-15  76

    umask函数为进程设置文件模式创建屏蔽字,并返回以前的值。函数原型为:

    #include <sys/stat.h>

    mode_t umask(mode_t cmask);

    cmask是由下表列出的9个常量中的若干个按位“或”构成的

    S_IRUSR       用户读

    S_IWUSR      用户写

    S_IXUSR       用户执行

    S_IRGRP       组读

    S_IWGRP      组写

    S_IXGRP       组执行

    S_IROTH       其他读

    S_IWOTH      其他写

    S_IXOTH       其他执行

    在Linux中一个文件的权限分为3组9个权限  分别为上面列出的9个,组间的顺序为用户,组,其他。例如:

    ls -l test

    -rw-rw-rw- 1 shmily shmily 0  5月  6 17:16 test

    表示test文件的权限为:用户可读可写,组可读可写,其他可读可写 (r代表可读 w代表可写 x代表可执行 -代表未设置)

    可用三位8进制数表示 则test的权限为666

    ————————————————————————————————————————————————————————————————————————————

    umask的主要作用是在创建文件时设置或者屏蔽掉文件的一些权限

    在创建一个文件时要指明该文件的权限,open函数的最后一个参数mode并不是要设置的权限,它需要执行以下操作

    mode & (~cmask)

    例如《APUE》中的4_3的函数

    #include "apue.h" #include <fcntl.h>    #define RWRWRW (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH)    int main(void) {          umask(0);          if (creat("foo", RWRWRW) < 0)             err_sys("create error for foo");          umask(S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH);          if (creat("bar", RWRWRW) < 0)              err_sys("creat error for bar");          return 0; }

    在最初cmask为0,即 000 000 000

    creat函数时设置mode为666

    mode & (~cmask) = 110 110 110 & 111 111 111 = 110 110 110

    所以foo文件的权限就是rw-rw-rw-

    然后cmask为066,即000 110 110

    crear函数的mode仍为666

    mode & (~cmask) = 110 110 110 & 111 001 001 = 110 000 000

    所以bar文件的权限为rw-------

    shmily@pc-Shmily:~/code/UnixCode$ ls -l foo bar -rw------- 1 shmily shmily 0  5月  6 17:16 bar -rw-rw-rw- 1 shmily shmily 0  5月  6 17:16 foo  

    Processed: 0.010, SQL: 10