open函數
定義函數:
int open(const char * pathname, int flags);
int open(const char * pathname, int flags, mode_t mode);
函數說明:
參數flags所能使用的與法
O_RDONLY以只讀方式打開文件
O_WRONLY以只寫方式打開文件
O_RDWR以可讀寫方式打開文件.上述三種旗標是互斥的,也就是不可同時使用,但可與下列的旗標利用OR(|)運算符組合.
O_CREAT若欲打開的文件不存在則自動建立該文件.
O_EXCL如果O_CREAT也被設置,此指令會去檢查文件是否存在.文件若不存在則建立該文件,否則將導致打開文件錯誤.此外,若O_CREAT與O_EXCL同時設置,並且欲打開的文件為符號連接,則會打開文件失敗.
O_NOCTTY如果欲打開的文件為終端機設備時,則不會將該終端機當成進程控制終端機.
O_TRUNC若文件存在並且以可寫的方式打開時,此旗標會令文件長度清為0,而原來存於該文件的資料也會消失.
O_APPEND當讀寫文件時會從文件尾開始移動,也就是所寫入的數據會以附加的方式加入到文件後面.
O_NONBLOCK以不可阻斷的方式打開文件,也就是無論有無數據讀取或等待,都會立即返回進程之中.
O_NDELAY同O_NONBLOCK.
O_SYNC以同步的方式打開文件.
O_NOFOLLOW如果參數pathname所指的文件為一符號連接,則會令打開文件失敗.
O_DIRECTORY如果參數pathname所指的文件並非為一目錄,則會令打開文件失敗。 注:此為Linux2. 2以後特有的旗標,以避免一些系統安全問題.
參數mode則有下列數種組合,只有在建立新文件時才會生效,此外真正建文件時的權限會受到umask值所影響,因此該文件權限應該為(mode-umaks).
S_IRWXU00700 權限, 代表該文件所有者俱有可讀、可寫及可執行的權限.
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 權限, 代表其他用戶具有可執行的權限.
返回值:若所有欲核查的權限都通過了檢查則返回0 值, 表示成功, 只要有一個權限被禁止則返回-1.
錯誤代碼:
EEXIST 參數pathname 所指的文件已存在, 卻使用了O_CREAT 和O_EXCL 旗標.
EACCESS 參數pathname 所指的文件不符合所要求測試的權限.
EROFS 欲測試寫入權限的文件存在於只讀文件系統內.
EFAULT 參數pathname 指針超出可存取內存空間.
EINVAL 參數mode 不正確.
ENAMETOOLONG 參數pathname 太長.
ENOTDIR 參數pathname 不是目錄.
ENOMEM 核心內存不足.
ELOOP 參數pathname 有過多符號連接問題.
EIO I/O 存取錯誤.
附加說明:使用access()作用戶認證方面的判斷要特別小心,例如在access()後再作open()空文件可能會造成系統安全上的問題.
範例
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
main()
{
int fd, size;
char s[] = "Linux Programmer!\n", buffer[80];
fd = open("/tmp/temp", O_WRONLY|O_CREAT);
write(fd, s, sizeof(s));
close(fd);
fd = open("/tmp/temp", O_RDONLY);
size = read(fd, buffer, sizeof(buffer));
close(fd);
printf("%s", buffer);
}
執行
Linux Programmer!
留言列表