您好,登錄后才能下訂單哦!
本篇內容介紹了“Linux操作文件系統怎么調用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
需要引入的頭文件:
#inlcude<unistd.h>
打開一個已存在的文件
int open(const char *pathname, int flags);
新建一個文件并創建權限
int open(const char *pathname, int flags, mode_t mode);
pathname:將要打開的文件路徑和名稱
flags:打開標志
標志介紹:
The argument flags must include one of the following access modes: O_RDONLY, O_WRONLY, or O_RDWR. These request opening the file read- only, write-only, or read/write, respectively.
O_RDONLY 只讀打開
O_RDWR 讀寫打開
O_CREAT 文件不存在則創建
O_APPEND 文件末尾追加
O_TRUNC 清空文件,重新寫入 mode
The following symbolic constants are provided for mode: S_IRWXU 00700 user (file owner) has read, write, and execute permission S_IRUSR 00400 user has read permission S_IWUSR 00200 user has write permission S_IXUSR 00100 user has execute permission S_IRWXG 00070 group has read, write, and execute permission S_IRGRP 00040 group has read permission S_IWGRP 00020 group has write permission S_IXGRP 00010 group has execute permission S_IRWXO 00007 others have read, write, and execute permission S_IROTH 00004 others have read permission S_IWOTH 00002 others have write permission S_IXOTH 00001 others have execute permission
返回值:文件描述符
ssize_t read(int fd, void *buf, size_t count);
參數介紹
fd:對應打開的文件描述符buf : 存放數據的空間count: 計劃一次從文件中讀多少字節數據返回值: 實際讀到的字節數
ssize_t write(int fd, const void *buf, size_t count);
參數介紹:
fd :對應打開的文件描述符buf:存放待寫入的數據count:計劃一次向文件中寫入多少數據
int close(int fd);
fd :對應的文件描述符
如果父進程先打開一個文件,fork 后子進程是否可以共享使用?
文件內容
代碼
#include<stdio.h> #include<unistd.h> #include<assert.h> #include<fcntl.h> #include<stdlib.h> int main() { char buff[128] = {0}; int fd = open("myfile.txt", O_RDONLY); pid_t pid = fork(); assert(pid != -1); if (pid == 0) { read(fd, buff, 1); printf("child buff = %s\n", buff); sleep(1); read(fd, buff, 1); printf("child buff = %s\n", buff); } else { read(fd, buff, 1); printf("parent buff = %s\n", buff); sleep(1); read(fd, buff, 1); printf("parent buff = %s\n", buff); } close(fd); exit(0); }
運行結果:
結論:
由于 fork 創建的子進程的 PCB 是拷貝父進程的,子進程的 PCB 中的文件表指向打開文件的指針只是拷貝了父進程 PCB 中的值,所以父子進程共享父進程 fork 之前打開的所有文件描述符。
完成對一個文件的復制(類似命令:cp)
原文件內容為:
代碼:
#include<stdio.h> #include<unistd.h> #include<fcntl.h> #include<stdlib.h> #include<assert.h> int main(void) { char buff[128] = {0}; int fdr = open("myfile.txt", O_RDONLY); assert(fdr != -1); int fdw = open("newfile.txt", O_WRONLY | O_CREAT, 0600); assert(fdw != -1); int n = 0; while (n = read(fdr, buff, 128) > 0) { write(fdw, buff, n); } close(fdr); close(fdw); exit(0); }
運行示例:
可以看到newfile.txt創建成功
區別: 系統調用的實現在內核中,屬于內核空間,庫函數的實現在函數庫中,屬于用戶空間。
系統調用執行過程:
“Linux操作文件系統怎么調用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。