fcntl函數(網絡編程會用)

#include <unistd.h>

#include <fcntl.h>

int fcntl(int fd, int cmd);

int fcntl(int fd, int cmd, long arg);//long 長整型

int fcntl(int fd, int cmd, struct flock *lock);

可見fcntl函數是一個可變參數函數(函數的形參數目和類型不只是一種)。

作用:改變已經打開的文件的屬性,如一個文件以只讀的方式打開后,如果想要再不關閉重新打開文件的前提下可以向文件里追加寫入內容,則可以使用fcntl函數來修改其屬性。

下面僅介紹常用的情況:第一個函數和第二個函數。

int fcntl(int fd, int cmd); 用于實現文件描述符的拷貝(重定向),功能與dup一樣。cmd采用參數:F_DUPFD(宏定義)。 返回值則為復制的文件描述符,錯誤返回-1。

int fcntl(int fd, int cmd, long arg); 用于實現:1.獲得文件狀態標記;2.設置文件狀態標記。

獲得文件狀態標記:cmd指定為F_GETFL,第三個參數arg直接為0即可,返回值即為文件狀態標記:O_RDONLY(只讀打開)、O_WRONLY(只寫打開)、O_RDWR(讀寫打開)、O_EXEC(執行打開)、O_SEARCH(搜索打開目錄)、O_APPEND(追加寫)、O_NONBLOCK(非阻塞模式),這些參數都是宏定義,為int型。錯誤則返回-1。

設置文件狀態標記(即在文件打開的情況下可修改文件屬性):cmd參數為F_SETFL,第三個參數arg(長整型)為:O_APPEND(可追加寫)、O_NONBLOCK(設置為非阻塞模式)。

其它功能:1.獲得或設置文件描述符標記,cmd參數為:F_GETFD或F_SETFD。2.獲得或設置異步I/O所有權,cmd參數為:F_GETOWN或F_SETOWN。3.獲得或設置記錄鎖,cmd參數為:F_GETLK、F_SETLK或F_SETLKW。

//在文件只讀情況下,修改為可追加寫入
#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>int main(void)
{int fd;int flag;// 測試字符串char *p = "我們是一個有中國特色的社會主義國家!!!!!!";char *q = "社會主義好哇。";// 只寫的方式打開文件fd = open("test.txt", O_WRONLY);if(fd == -1){perror("open");exit(1);}// 輸入新的內容,該部分會覆蓋原來舊的內容if(write(fd, p, strlen(p)) == -1){perror("write");exit(1);}// 使用 F_GETFL 命令得到文件狀態標志flag = fcntl(fd, F_GETFL, 0);if(flag == -1){perror("fcntl");exit(1);}// 將文件狀態標志添加 ”追加寫“ 選項flag |= O_APPEND;     // flag = flag | O_APPEND 這是一個位或運算   注意使用方法!!!// 將文件狀態修改為追加寫if(fcntl(fd, F_SETFL, flag) == -1){perror("fcntl -- append write");exit(1);}// 再次輸入新內容,該內容會追加到舊內容的后面if(write(fd, q, strlen(q)) == -1){perror("write again");exit(1);}// 關閉文件close(fd);return 0;
}

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/385382.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/385382.shtml
英文地址,請注明出處:http://en.pswp.cn/news/385382.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

189. 旋轉數組

給定一個數組&#xff0c;將數組中的元素向右移動 k 個位置&#xff0c;其中 k 是非負數。 示例 1: 輸入: [1,2,3,4,5,6,7] 和 k 3 輸出: [5,6,7,1,2,3,4] 解釋: 向右旋轉 1 步: [7,1,2,3,4,5,6] 向右旋轉 2 步: [6,7,1,2,3,4,5] 向右旋轉 3 步: [5,6,7,1,2,3,4]示例 2: 輸…

58. 最后一個單詞的長度

給定一個僅包含大小寫字母和空格 的字符串&#xff0c;返回其最后一個單詞的長度。 如果不存在最后一個單詞&#xff0c;請返回 0 。 說明&#xff1a;一個單詞是指由字母組成&#xff0c;但不包含任何空格的字符串。 示例: 輸入: "Hello World" 輸出: 5 clas…

CPU和MMU(內存管理單元)

CPU的架構&#xff1a;要求能夠理解從源程序到微指令的整個經歷過程&#xff1a;存儲器的層次結構&#xff08;網絡資源下載到硬盤、磁盤緩存、內存、Cache、寄存器&#xff09;&#xff1b;CPU的四大部分&#xff1a;ALU、CU、中斷系統和寄存器&#xff1b;程序執行的整個過程…

【C++ Primer | 09】容器適配器

一、stack s.push(): 向棧內壓入一個成員&#xff1b; s.pop(): 從棧頂彈出一個成員&#xff1b; s.empty(): 如果棧為空返回true&#xff0c;否則返回false&#xff1b; s.top(): 返回棧頂&#xff0c;但不刪除成員&#xff1b; s.size(): 返回棧內元素…

進程控制塊PCB(進程描述符)

&#xff08;1&#xff09;PCB 每個進程在內核中都有一個進程控制塊&#xff08;PCB&#xff09;來維護進程相關的信息&#xff0c;Linux內核的進程控制塊是task_struct結構體。grep -r “task_struct” / 可以查找根目錄下&#xff0c;包含task_struct的文件文件。或者 find…

103. 二叉樹的鋸齒形層次遍歷

給定一個二叉樹&#xff0c;返回其節點值的鋸齒形層次遍歷。&#xff08;即先從左往右&#xff0c;再從右往左進行下一層遍歷&#xff0c;以此類推&#xff0c;層與層之間交替進行&#xff09;。 例如&#xff1a; 給定二叉樹 [3,9,20,null,null,15,7], 3 / \ 9 20 /…

fork、getpid、getppid函數

#include <unistd.h> pid_t fork(void); 作用&#xff1a;創建一個子進程。 到目前為止&#xff0c;我們可以直到兩種創建進程的方法&#xff1a;1. 通過執行二進制文件來創建一個進程&#xff0c;如&#xff1a;./a.out /bin/ls&#xff1b;2.通過fork函數來創建一個…

107. 二叉樹的層次遍歷 II

給定一個二叉樹&#xff0c;返回其節點值自底向上的層次遍歷。 &#xff08;即按從葉子節點所在層到根節點所在的層&#xff0c;逐層從左向右遍歷&#xff09; 例如&#xff1a; 給定二叉樹 [3,9,20,null,null,15,7], 3/ \9 20/ \15 7返回其自底向上的層次遍歷為&#xff…

循環創建N個子進程

以循環創建5個進程為例&#xff0c;給出如下代碼&#xff0c;分析其錯誤&#xff1a; #include <stdio.h> #include <stdlib.h> #include <unistd.h>int main(void) {int i;pid_t pid;printf("xxxxxxxxxxx\n");for (i 0; i < 5; i){pid fork…

【C++ Primer | 19】控制內存分配

1. 測試代碼&#xff1a; #include <iostream> #include <new> #include <cstring> #include <cstdlib> using namespace std;void* operator new(size_t size) {cout << "global Override operator new" << endl;if (void* p…

getuid、geteuid、getgid和getegid函數

#include <unistd.h> #include <sys/types.h> uid_t getuid(void); uid_t geteuid(void); 作用&#xff1a;getuid返回當前進程的實際用戶ID&#xff1b;geteuid返回當前用戶的有效用戶ID。這兩個總是成功&#xff0c;不會失敗。 #include <unistd.h> #…

【第15章】虛函數

一、為什么基類中的析構函數要聲明為虛析構函數&#xff1f; 直接的講&#xff0c;C中基類采用virtual虛析構函數是為了防止內存泄漏。具體地說&#xff0c;如果派生類中申請了內存空間&#xff0c;并在其析構函數中對這些內存空間進行釋放。假設基類中采用的是非虛析構函數&am…

進程共享(讀時共享寫時復制)

父子進程之間在剛fork后。父子相同處: 全局變量、.data、.bbs、.text、棧、堆、環境變量、用戶ID、宿主目錄&#xff08;進程用戶家目錄&#xff09;、進程工作目錄、信號處理方式等等&#xff0c;即0~3G的用戶空間是完全一樣的。父子不同處: 1.進程ID 2.fork返回值 3.父進…

【C++ Primer | 08】IO庫

一、istringstream類 描述&#xff1a;從流中提取數據&#xff0c;支持 >> 操作 這里字符串可以包括多個單詞&#xff0c;單詞之間使用空格分開 #include <iostream> #include <sstream> using namespace std; int main() {istringstream istr(&quo…

gdb調試(如何跟蹤指定進程)

使用gdb調試的時候&#xff0c;gdb只能跟蹤一個進程。可以在fork函數調用之前&#xff0c;通過指令設置gdb調試工具跟蹤父進程或者是跟蹤子進程。默認跟蹤父進程。 set follow-fork-mode child 命令設置gdb在fork之后跟蹤子進程。 set follow-fork-mode parent 設置跟蹤父進程…

【Leetcode | 01】Backtracking

回溯算法序號題號117. 電話號碼的字母組合222. 括號生成 39. 組合總和 40. 組合總和 II 46. 全排列 47. 全排列 II 60. 第k個排列 77. 組合 78. 子集 90. 子集 II 93. 復原IP地址 131. 分割回文串 216. 組合總和 III 306. 累加數 357. 計算各個位數不同的數字個數 401. 二進…

1033. 舊鍵盤打字(20)

舊鍵盤上壞了幾個鍵&#xff0c;于是在敲一段文字的時候&#xff0c;對應的字符就不會出現。現在給出應該輸入的一段文字、以及壞掉的那些鍵&#xff0c;打出的結果文字會是怎樣&#xff1f; 輸入格式&#xff1a; 輸入在2行中分別給出壞掉的那些鍵、以及應該輸入的文字。其中對…

1038. 統計同成績學生(20)

本題要求讀入N名學生的成績&#xff0c;將獲得某一給定分數的學生人數輸出。 輸入格式&#xff1a; 輸入在第1行給出不超過105的正整數N&#xff0c;即學生總人數。隨后1行給出N名學生的百分制整數成績&#xff0c;中間以空格分隔。最后1行給出要查詢的分數個數K&#xff08;不…

EXEC函數族的一般規律

事實上&#xff0c;只有execve是真正的系統調用&#xff0c;其它五個函數最終都調用execve&#xff0c;所以execve在man手冊第2節&#xff0c;其它函數在man手冊第3節。這些函數之間的關系如下圖所示。

exit與_exit函fork與vfork函數

#include <stdlib.h> void exit(int status); #include <unistd.h> void _exit(int status); exit函數與_exit函數一樣&#xff0c;都是系統函數&#xff0c;且都是用來終止一個進程的&#xff0c;無論在程序中的什么位置&#xff0c;只要執行這exit或_exit系統…