今天剛學完基本的文件操作,特地記錄一些心得。
umask
umask
是一個系統變量,在創建文件的時候起掩碼的作用:假設要創建的文件權限為 mode
,那么最終實際得到的文件權限為 mode & ~umask
。可以反過來理解為,umask 中看上去“允許”的權限,實際上是禁止的。例如,在 umask
為 001 的時候,創建的文件無論如何都不會將執行權限賦給其他用戶。可以使用 mode_t getumask (void)
和 mode_t umask (mode t mask)
函數分別讀寫 umask
。
off_t lseek(int fildes, off_t offset, int whence) 和 int fseek (FILE* stream, long int offset, int whence)
值得注意的是,如果想要從文件末尾向回跳過,例如,5 個字節(whence
設為 SEEK_END
),offset
應該設為 -5L。
int fflush(FILE* stream)
網上很多人在問如何清空標準輸入流。有人說用 fflush(stdin)
,實際上這只在 Windows 下有效(微軟自己擴展的)。在 Linux 下達到此目的最簡單的辦法就是強制讓標準輸入流認為已經讀到了緩沖區的末尾:stdin->_IO_read_ptr = stdin->_IO_read_end
。
int fgetc(FILE* stream)、int getc(FILE* stream) 和 int getchar(void)
為什么這些讀取字符的函數返回值的類型都是 int
而非 char
?因為如果不這樣,就無法返回表示文件末尾的 EOF
(-1)。
char* fgets(char* s, int n, FILE* stream) 和 char* gets(char* s)
用這兩個函數讀取一行文本不可靠,因為你永遠不可能知道下一行將有多少字符。推薦使用 ssize_t getline (char** lineptr, size_t* n, FILE* stream)
。
int sprintf(char* s, const char* format, ...) 和 int snprintf(char* s, size t size, const char* template, ...)
同樣由于無法預知將會產生多少字符而不太可靠。推薦使用 int asprintf(char** ptr, const char* template, ...)
。
int unlink(const char* filename)、int rmdir(const char* filename) 和 int remove(const char* filename)
在調用這三個函數之一后,文件并不一定會馬上刪掉,而是要等到所有打開此文件的線程都關閉文件之后。這可以作為一種管理臨時文件的編程技巧:創建臨時文件后立即調用刪除函數。
void* mmap(void* addr, size_t len, int prot, int flags, int fildes, off_t off)
off
必須為分頁大小的整數倍,否則會映射失敗。分頁大小可通過 int getpagesize(void)
得到,這通常是一個很大的數字,所以 off
一般設為 0。