[小技巧]open()函式建立檔案時便捷的許可權設定
阿新 • • 發佈:2018-12-10
[小技巧]open()函式建立檔案時便捷的許可權設定
2016年07月18日 17:14:12 嵐漾憶雨 閱讀數:3404更多
個人分類: LinuxC程式設計
版權宣告:本文為博主原創文章,未經博主允許不得轉載。 https://blog.csdn.net/baidu_35085676/article/details/51943657
open()函式建立檔案時便捷的許可權設定
標頭檔案
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
- 1
- 2
- 3
函式原型
int open( const char * pathname, int flags);
int open( const char * pathname,int flags, mode_t mode);
當flags引數包含O_REEAT時,需要對mode引數進行指定
- S_IRWXU,00700 許可權,代表該檔案所有者具有可讀、可寫及可執行的許可權。
- S_IRUSR 或S_IREAD,00400許可權,代表該檔案所有者具有可讀取的許可權。
- S_IWUSR 或S_IWRITE,00200 許可權,代表該檔案所有者具有可寫入的許可權。
- S_IXUSR 或S_IEXEC,00100 許可權,代表該檔案所有者具有可執行的許可權。
- S_IRWXG 00070許可權,代表該檔案使用者組具有可讀、可寫及可執行的許可權。
- S_IRGRP 00040 許可權,代表該檔案使用者組具有可讀的許可權。
- S_IWGRP 00020許可權,代表該檔案使用者組具有可寫入的許可權。
- S_IXGRP 00010 許可權,代表該檔案使用者組具有可執行的許可權。
- S_IRWXO 00007許可權,代表其他使用者具有可讀、可寫及可執行的許可權。
- S_IROTH 00004 許可權,代表其他使用者具有可讀的許可權
- S_IWOTH 00002許可權,代表其他使用者具有可寫入的許可權。
- S_IXOTH 00001 許可權,代表其他使用者具有可執行的許可權。
第三個引數也可用八進位制數字代替,比如0644表示-rw-r–r–
int fd;
fd = open("./a.c",O_CREAT,0644);
- 1
- 2
-rw-r--r-- 1 lyt lyt 0 7月 18 17:12 a.c