close

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!

arrow
arrow
    文章標籤
    C 程式語言
    全站熱搜

    Jungle 發表在 痞客邦 留言(0) 人氣()