C語言creat()函數:創建文件函數
頭文件:
#include <sys/types.h> #include <sys/stat.h> #include <fcntl.h>
定義函數:
int creat(const char * pathname, mode_tmode);
函數說明:
1、參數 pathname 指向欲建立的文件路徑字符串。
2、Creat()相當于使用下列的調用方式調用open()
open(const char * pathname, (O_CREAT|O_WRONLY|O_TRUNC));
錯誤代碼:關于參數 mode 請參考open()函數.
返回值:
- creat()會返回新的文件描述詞, 若有錯誤發生則會返回-1, 并把錯誤代碼設給errno.
- EEXIST參數:pathname 所指的文件已存在.
- EACCESS參數:pathname 所指定的文件不符合所要求測試的權限
- EROFS:欲打開寫入權限的文件存在于只讀文件系統內
- EFAULT參數:pathname 指針超出可存取的內存空間
- EINVAL參數:mode 不正確.
- ENAMETOOLONG參數:pathname 太長.
- ENOTDIR 參數:pathname 為一目錄
- ENOMEM :核心內存不足
- ELOOP 參數:pathname 有過多符號連接問題.
- EMFILE:已達到進程可同時打開的文件數上限
- ENFILE:已達到系統可同時打開的文件數上限
附加說明:creat()無法建立特別的裝置文件, 如果需要請使用mknod().
C語言open()函數:打開文件函數
頭文件:
#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()空文件可能會造成系統安全上的問題.
范例
#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);}
執行
C語言close()函數:關閉文件
頭文件:
定義函數:
函數說明:當使用完文件后若已不再需要則可使用 close()關閉該文件, 二close()會讓數據寫回磁盤, 并釋放該文件所占用的資源. 參數fd 為先前由open()或creat()所返回的文件描述詞.
返回值:若文件順利關閉則返回0, 發生錯誤時返回-1.
錯誤代碼:EBADF 參數fd 非有效的文件描述詞或該文件已關閉.
附加說明:雖然在進程結束時, 系統會自動關閉已打開的文件, 但仍建議自行關閉文件, 并確實檢查返回值.