umask()函数:此函数的主要作用是在创建文件时设置或者屏蔽掉文件的一些权限。一般与open()函数配合使用。
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的主要作用是在创建文件时设置或者屏蔽掉文件的一些权限,
int open( const char * pathname, int flags);
int open( const char * pathname,int flags, mode_t mode);
当创建一个文件并且要明确指定此文件的权限时,应该使用第二个open()函数,明确指定mode参数,所创建的文件最后的权限是:mode&(~mask)。默认的mask值是:022
在创建一个文件时要指明该文件的权限,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