umask函数:
相关函数:creat, open
头文件:#include
pes.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文件中有使用!
引用: