当前位置:   article > 正文

Linux学习笔记7——umask函数_hy.txt

hy.txt

  1. #include<sys/stat.h>
  2. mode_t umask(mode_t cmask);
umask函数为进程设置文件模式创建屏蔽字,并返回改动之前的值。


这个函数的功能比较奇葩,他实际上是规定了创建文件时哪些功能是不能用的,即便你创建时赋予了这个功能,他也将其无视。具体来说,如果umask中设置了“用户读”,则你创建的任何文件必然没有“用户读”权限,哪怕你在open或creat的时候明文表示你需要“用户读”权限。

举例如下:

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <memory.h>
  4. #include <sys/stat.h>
  5. #include <unistd.h>
  6. #include <fcntl.h>
  7. void err_sys(char *);
  8. void err_sys(char *err_txt)
  9. {
  10. printf("%s\n",err_txt);
  11. exit(1);
  12. }
  13. int main(int argc, char* argv[])
  14. {
  15. //4.9 umask 文件模式创建屏蔽字
  16. printf("old umask = %d\n", umask(0));
  17. if(creat("jxl.txt", S_IRUSR) < 0)
  18. err_sys("creat error for jxl.txt");
  19. umask(S_IRUSR);
  20. if(creat("hy.txt", S_IRUSR) < 0)
  21. err_sys("creat error for hy.txt");
  22. exit (0);
  23. }

创建jxl.txt前将umask清零,表示没有任何权限被屏蔽,然后以“用户读”的方式创建文件

创建hy.txt前将umask的“用户读”置位,实际上代表屏蔽“用户读”权限,然后再以“用户读”的方式创建文件

执行结果如下:


程序打印出了系统默认的umask值,为2,代表系统默认不开放“其他写”权限。

jxl.txt的权限没有被限制,所以最终其按照我们的设定获得了“用户读”权限

hy.txt由于屏蔽了“用户写”,但是又按照“用户写”来创建文件,最终导致其没有获得任何权限。


注意:

更改进程的文件模式创建屏蔽字,并不影响其父进程的文件模式创建屏蔽字。


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

闽ICP备14008679号