我是靠谱客的博主 包容红酒,这篇文章主要介绍UNIX - umask函数,创建文件模式屏蔽字,现在分享给大家,希望可以做个参考。

umask函数用于为进程设置文件模式创建屏蔽字,并返回之前的屏蔽字。

复制代码
1
2
3
4
#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设置文件模式创建屏蔽字

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#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; }

运行上述代码之前查看当前文件模式创建屏蔽字:

复制代码
1
2
3
$ umask 0022

上述代码运行结果如下:

复制代码
1
2
3
4
$ 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中相应的位被关闭。
查看当前文件模式创建屏蔽字是否改变:

复制代码
1
2
3
$ umask 0022

通过umask命令在程序执行前后输出信息来看,文件模式创建屏蔽字没有改变,即更改进程的文件模式创建屏蔽字并不影响父进程(通常为shell)的屏蔽字。
umask是shell的内置(which 命令无输出)命令,用于输出当前文件模式创建屏蔽字:

复制代码
1
2
$ which umask

最后

以上就是包容红酒最近收集整理的关于UNIX - umask函数,创建文件模式屏蔽字的全部内容,更多相关UNIX内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(77)

评论列表共有 0 条评论

立即
投稿
返回
顶部