概述
umask函数用于为进程设置文件模式创建屏蔽字,并返回之前的屏蔽字。
#include <sys/types.h>
#include <sys/stat.h>
mode_t umask(mode_t mask);
其中,参数mask由以下9个文件访问权限位中的若干位“或“构成,这些位在/usr/include/x86_64-linux-gnu/sys/stat.h中定义。
表1. 文件访问权限位
st_mode | 含义 |
S_IRUSR | 用户读 |
S_IWUSR | 用户写 |
S_IXUSR | 用户执 |
S_IRGRP | 用户组读 |
S_IWGRP | 用户组写 |
S_IXGRP | 用户组执行 |
S_IROTH | 其它组读 |
S_IWOTH | 其它组写 |
S_IXOTH | 其它组执行 |
例1 使用umask设置文件模式创建屏蔽字
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <error.h>
#define MODE (S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP)
int main()
{
umask(0);
if (creat("file_old", MODE) < 0)
perror("creat file_old");
umask(077);
if (creat("file_new", MODE) < 0)
perror("creat file_new");
return 0;
}
运行上述代码之前查看当前文件模式创建屏蔽字:
$ umask
0022
上述代码运行结果如下:
$ ls -l file_*
-rw------- 1 rocky rocky 0 3月 8 09:56 file_new
-rw-rw---- 1 rocky rocky 0 3月 8 09:56 file_old
通过新创建文件的访问权限位,可以看出在文件模式创建屏蔽字中为1的位,文件mode中相应的位被关闭。
查看当前文件模式创建屏蔽字是否改变:
$ umask
0022
通过umask命令在程序执行前后输出信息来看,文件模式创建屏蔽字没有改变,即更改进程的文件模式创建屏蔽字并不影响父进程(通常为shell)的屏蔽字。
umask是shell的内置(which 命令无输出)命令,用于输出当前文件模式创建屏蔽字:
$ which umask
最后
以上就是包容红酒为你收集整理的UNIX - umask函数,创建文件模式屏蔽字的全部内容,希望文章能够帮你解决UNIX - umask函数,创建文件模式屏蔽字所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复