当前位置:   article > 正文

linux umask函数,C语言中umask函数的用法

mode&~umask

umask函数:

相关函数:creat, open

头文件:#include 

0818b9ca8b590ca3270a3433284dd417.pngpes.h>   #include 

定义函数:mode_t umask(mode_t mask);

函数说明:umask()会将系统umask值设成参数mask&0777后的值, 然后将先前的umask值返回。在使用open()建立新文件时, 该参数mode 并非真正建立文件的权限, 而是

(mode&~umask)的权限值。

例如:

在建立文件时指定文件权限为0666, 通常umask 值默认为022, 则该文件的真正权限则为0666&~022=0644, 也就是rw-r--r--返回值此调用不会有错误值返回. 返回值为原先系统的umask 值。

举例代码如下:

#include

#include

#include

#include

/*

* Linux下设置新建文件时的默认权限掩码

* 由umask函数设置

* sys/types.h,sys/stat.h

* mode_t umask(mode_t umask)

* 传入四位八进制数,返回系统原先的权限掩码

* 0666对应Linux文件权限中的0000

* 0444对应0222

*

*/

int main(void)

{

mode_t new_umask, old_umask;

new_umask=0666;

old_umask=umask(new_umask);

printf("系统原来的权限掩码是:%o/n",old_umask);

printf("系统新的权限掩码是:%o/n",new_umask);

system("touch liu1");

printf("创建了文件liu1/n");

new_umask=0444;

old_umask=umask(new_umask);

printf("系统原来的权限掩码是:%o/n",old_umask);

printf("系统新的权限掩码是:%o/n",new_umask);

system("touch liu2");

printf("创建了文件liu2/n");

system("ls liu1 liu2 -l");

return 0;

/*执行结果

* 系统原来的权限掩码是:22

* 系统新的权限掩码是:666

* 创建了文件liu1

* 系统原来的权限掩码是:666

* 系统新的权限掩码是:444

* 创建了文件liu2

* ---------- 1 jinyong jinyong 0 2010-12-28 21:57 liu1

* --w--w--w- 1 jinyong jinyong 0 2010-12-28 21:57 liu2

*/

}

该函数在android的init.c文件中有使用!

引用:

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/49423
推荐阅读
相关标签
  

闽ICP备14008679号