UNIX - umask函数,创建文件模式屏蔽字

umask函数在UNIX系统中用于设置文件模式创建屏蔽字,影响新创建文件的权限。它返回之前的屏蔽字,参数mask包含9个访问权限位。通过示例展示了umask如何影响文件的访问权限,即使在执行后,umask命令显示的屏蔽字并未改变,说明它仅影响子进程而非父进程。umask也是shell的一个内置命令。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值