umask函数

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的函数

  1. #include "apue.h"  
  2. #include <fcntl.h>  
  3.     
  4. #define RWRWRW (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH)  
  5.     
  6. int main(void)  
  7. {  
  8.         umask(0);  
  9.         if (creat("foo", RWRWRW) < 0)  
  10.             err_sys("create error for foo");  
  11.         umask(S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH);  
  12.         if (creat("bar", RWRWRW) < 0)  
  13.             err_sys("creat error for bar");  
  14.         return 0;  
  15. }  
  16.           

在最初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
### C语言中实现 `umask` 函数的方式及代码示例 #### 一、`umask` 函数简介 `umask` 是一个系统调用,用于设置文件模式创建掩码(File Mode Creation Mask),它决定了新创建文件或目录的默认权限。通过调用 `umask`,可以指定哪些权限位被禁用。此函数返回之前的掩码值,并应用新的掩码值[^4]。 #### 二、`umask` 的工作原理 在 Linux 系统中,当创建一个新文件或目录时,默认的最大权限分别为: - 文件:`0666` (即 `-rw-rw-rw-`) - 目录:`0777` (即 `drwxrwxrwx`) 最终的实际权限由以下公式计算得到: \[ \text{实际权限} = \text{最大权限} - \text{umask} \] 例如,如果设置了 `umask 022`,那么新文件的权限将是 \(0666 - 0022 = 0644\) (`-rw-r--r--`),而新目录的权限则为 \(0777 - 0022 = 0755\) (`drwxr-xr-x`) [^4]。 #### 三、C语言中实现 `umask` 的代码示例 以下是使用 C 语言实现 `umask` 功能的一个完整示例: ```c #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #define RWRWRW (S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH) int main(void) { mode_t old_mask; // Step 1: 设置 umask 为 0,表示不对文件权限进行任何屏蔽 old_mask = umask(0); printf("Old mask was %o\n", old_mask); // Step 2: 创建第一个文件,权限为 RWRWRW if (creat("umask1.txt", RWRWRW) == -1) { perror("create umask1"); return 1; } // Step 3: 更改 umask,屏蔽组和其他用户的读写权限 umask(S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH); // Step 4: 创建第二个文件,观察权限变化 if (creat("umask2.txt", RWRWRW) == -1) { perror("create umask2"); return 1; } return 0; } ``` 在这个例子中: 1. 使用 `umask(0)` 将掩码设为零,意味着不会屏蔽任何权限。 2. 调用 `creat()` 创建名为 `umask1.txt` 的文件,其权限应为 `0666`(因为未受到 `umask` 影响)。 3. 再次调用 `umask` 来屏蔽组和其他用户的读写权限。 4. 继续调用 `creat()` 创建另一个文件 `umask2.txt`,此时由于 `umask` 的影响,该文件的权限会被相应减少[^4]。 --- #### 四、注意事项 1. **返回值的意义** `umask` 返回之前设置的掩码值,因此可以通过保存并恢复旧的掩码值来确保程序行为一致。 2. **权限范围限制** 新文件的权限始终受限于 `umask` 所定义的屏蔽规则,即使尝试赋予更高的权限也无法突破这一约束[^4]。 3. **线程安全性** `umask` 是一个全局性的设置,会影响同一进程中所有后续的文件操作。因此,在多线程环境中需谨慎使用,以免引发不可预期的行为[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值