C語言open()函數:打開文件函數(轉)


相關函數:read, write, fcntl, close, link, stat, umask, unlink, fopen

頭文件:#include <sys/types.h>    #include <sys/stat.h>    #include <fcntl.h>

定義函數:
    int open(const char * pathname, int flags);
    int open(const char * pathname, int flags, mode_t mode);

函數說明:

參數 pathname 指向欲打開的文件路徑字符串. 下列是參數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()空文件可能會造成系統安全上的問題.

范例

 1 #include <unistd.h>
 2 #include <sys/types.h>
 3 #include <sys/stat.h>
 4 #include <fcntl.h>
 5 main()
 6 {
 7     int fd, size;
 8     char s[] = "Linux Programmer!\n", buffer[80];
 9     fd = open("/tmp/temp", O_WRONLY|O_CREAT);
10     write(fd, s, sizeof(s));
11     close(fd);
12     fd = open("/tmp/temp", O_RDONLY);
13     size = read(fd, buffer, sizeof(buffer));
14     close(fd);
15     printf("%s", buffer);
16 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM