umask函数

 

说明:只供学习交流,转载请注明出处

 

umask用于影响新建立文件的默认权限。当新建立一个文件或目录时,系统会根据umask的值来“剥夺”文件或目录的相应权限。例如,如果umask的值是022的话,表示新创建的文件的权限是666-022=644(出于安全考虑,新创建的文件没有执行权限。因此,权限是(666-022),而不是(777-022)),即“rw-r--r--”的形式)对目录而言是(777-022),即“rwxr-xr-x”的形式。

Linux系统同样提供了umask函数用于在程序中修改umask的值,以确定程序创建的文件的权限。函数具体信息见下表:

umask函数

 

头文件

<sys/types.h>

<sys/stat.h>

函数形式

mode_t umask(mode_t mask);

返回值

成功

失败

是否设置errno

修改前的umask

系统调用总是成功

无相关信息

 

说明:umask函数用于修改进程的文件创建权限,umask往往与openmkdir函数或其他的系统调用搭配使用,用于创建新的文件时获得不同的权限。默认情况下,进程的umask值为S_IWGRP|S_IWOTH(也就是八进制的022)。

 

错误信息:

该系统调用总是执行成功,因此没有错误信息。

 

实例:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

int main(void)
{
    int fd1;
    int fd2;
    
    //创建名为test的文件,权限为777,即所有用户都拥有读写和执行权限
    fd1 = open("test", O_CREAT | O_RDWR, 0777);
    if ( fd1 < 0 )
    {
        perror("Cannot create the test file");
        return (1);
    }     
    
    close(fd1);
    
    struct stat file_stat;
    
     //调用stat函数获得test文件的权限
     if (stat("test", &file_stat) == -1)
     {
         perror("Cannot get the information of the file!\n");
         return (1);
     }     
     
     //输出权限
     printf("Permission is : %o\n", file_stat.st_mode & 0x1ff);
     
     //调用umask函数修改进程创建文件的umask的值
     //除了使用下面的形式,还可以使用umask(077)这样的形式
     umask(S_IWGRP | S_IRGRP | S_IXGRP | S_IROTH | S_IWOTH | S_IXOTH);
     
      //创建名为test1的文件,权限为777
      fd2 = open("test1", O_CREAT | O_RDWR, 0777);
      if ( fd2 < 0 )
      {
          perror("Cannot create the test file");
          return (1);
      }     
      
      close(fd2);
      
      //调用stat函数获得test1的权限
      if ( stat("test1", &file_stat) == -1 )
      {
          perror("Cannot get the information of the file!\n");
          return (1);
      }     
      
      //输出修改umask后的test1的权限值
      printf("After Modify umask value, Premission is : %o\n", file_stat.st_mode & 0x1ff);
      
       return (1); 
}    

运行结果:
[root@localhost test]# ./umask 
Permission is : 755
After Modify umask value, Premission is : 700
[root@localhost test]# ll
total 96
-r--r--r-x 1 root root 7778 Apr 30 01:43 chdir
-rw-rw-rw- 1 root root 1398 Apr 30 01:43 chdir.cpp
-rwxr-xr-x 1 root root 5046 May  1 01:03 chmod
-rw-rw-rw- 1 root root  476 May  1 01:03 chmod.c
-rwxr-xr-x 1 root root 5062 May  1 01:43 chown
-rw-rw-rw- 1 root root  393 May  1 01:43 chown.c
-r--r--r-x 1 root root 7102 Apr 29 23:33 getcwd
-rw-rw-rw- 1 root root  560 Apr 29 23:33 getcwd.cpp
-rw-r--r-- 1 root root    0 May  2 22:03 hello
-rwxr-xr-x 1 root root 6145 Apr 30 18:20 mkdir
-rwxr--r-- 1 root root  337 Apr 30 18:20 mkdir.cpp
-rwxr-xr-x 1 root root 7440 Apr 30 01:23 pathconf
-rw-rw-rw- 1 root root  966 Apr 30 01:24 pathconf.cpp
-rwxr-xr-x 1 root root 5860 Apr 30 23:33 stat
-rwxr--r-- 1 root root 1778 Apr 30 23:33 stat.c
-rwxr-xr-x 1 root root    0 May  2 22:02 test
-rwx------ 1 root root    0 May  2 22:02 test1
-rwxr-xr-x 1 root root 5690 May  2 22:02 umask
-rw-rw-rw- 1 root root 1515 May  2 22:02 umask.c


 

 

 

 

### 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、付费专栏及课程。

余额充值