dup、dup2、fcntl

dup、dup2,復制文件描述符

  int dup(int oldfd);  //返回文件描述表中沒有被占用的最小可用的描述符,新舊描述符作用相同

  int dup2(int oldfd, int newfd);  //如果new已經被打開,先關閉再拷貝就會指向同一個文件,如果old和new是同一個就直接返回舊的

  不管這么復制,文件指針只有一個。

?

其余請參考:https://blog.csdn.net/silent123go/article/details/71108501

  

fcntl、修改已打開文件的屬性

  int fcntl(int fd, int cmd, long arg)

  主要使用于獲得/設置文件標記? ? F_GETFL (自讀打開 O_RDONLY、只寫打開 O_WRONLY、讀寫打開 O_RDWR、執行打開 O_EXEC、搜索打開目錄 O_SEARCH、追加寫 O_APPEND、非阻塞模式 O_NONBLOCK)

                ?F_SETFL可更改幾個標識(O_APPEND、O_NONBLOCK)

  

轉載于:https://www.cnblogs.com/lr1402585172/p/10490716.html

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

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

相關文章

進程

創建子進程:fork調用, 一次fork調用返回兩個值,1、返回子進程的pid(非負整數) 2、返回0 父進程的fork返回子進程的id,子進程的fork返回0(表示執行成功) 創建單個子進程: …

Ubuntu在vmware虛擬機無法上網的解決方法

http://blog.csdn.net/xueyushenzhou/article/details/50460183 在vmware中安裝Ubuntu之后,我們希望基本的功能如上網、傳輸文件等功能都是可用的,但是經常遇到不能上網的情況。使用筆記本時,我們經常希望能通過無線網卡上網,但是…

exec函數族

fork創建子進程后執行的是和父進程相同的程序(但有可能執行不同的代碼分支),子進程往往要調用一種exec函數以執行另一個程序。當進程調用一種exec函數時,該進程的用戶空間代碼和數據完全被新程序替換,從新程序的啟動例…

IO 多路復用之poll總結

http://www.cnblogs.com/Anker/p/3261006.html IO多路復用之poll總結 1、基本知識 poll的機制與select類似,與select在本質上沒有多大差別,管理多個描述符也是進行輪詢,根據描述符的狀態進行處理,但是poll沒有最大文件描述符數量的…

wait、waitpid

父進程調用wait函數可以回收子進程的終止信息,該函數有三個功能:(一次wait調用回收一個子進程 回收多個用循環) 1、阻塞等待子進程退出 2、回收子進程殘留資源 3、獲取子進程結束狀態(退出原因) pid_t wait…

C++項目中的extern C {}

http://www.cnblogs.com/skynet/archive/2010/07/10/1774964.html 引言 在用C的項目源碼中,經常會不可避免的會看到下面的代碼: 123456789#ifdef __cplusplusextern "C" {#endif/*...*/#ifdef __cplusplus}#endif它到底有什么用呢,…

管道

管道,其本質是一個偽文件(實為內核緩沖區);由兩個文件描述符引用,一個表示讀端、一個表示寫端;規定數據從管道的寫端流入,讀端流出。 管道的原理:管道實為內核使用環形隊列機制&…

C/S、B/S的區別

C/S結構,即Client/Server(客戶機/服務器)結構,是大家熟知的軟件系統體系結構,通過將任務合理分配到Client端和Server端,降低了系統的通訊開銷,可以充分利用兩端硬件環境的優勢。早期的軟件系統多以此作為首選設計標準。…

extern c用法解析

http://www.jianshu.com/p/5d2eeeb93590 引言C保留了一部分過程式語言的特點,因而它可以定義不屬于任何類的全局變量和函數。但是,C畢竟是一種面向對象的程序設計語言,為了支持函數的重載,C對全局函數的處理方式與C有明顯的不同。…

C語言實現單鏈表(帶頭結點)的基本操作(創建,頭插法,尾插法,刪除結點,打印鏈表)

http://blog.csdn.net/xiaofeige567/article/details/27484137 C語言實現單鏈表&#xff08;帶頭結點&#xff09;的基本操作&#xff08;創建&#xff0c;頭插法&#xff0c;尾插法&#xff0c;刪除結點&#xff0c;打印鏈表&#xff09; [plain] view plaincopy #include<…

靜態網頁與動態網頁區別

一、靜態web頁面&#xff1a;1、在靜態Web程序中&#xff0c;客戶端使用Web瀏覽器&#xff08;IE、FireFox等&#xff09;經過網絡(Network)連接到服務器上&#xff0c;使用HTTP協議發起一個請求&#xff08;Request&#xff09;&#xff0c;告訴服務器我現在需要得到哪個頁面&…

單向循環鏈表C語言實現

http://blog.csdn.net/morixinguan/article/details/51771633 我們都知道&#xff0c;單向鏈表最后指向為NULL&#xff0c;也就是為空&#xff0c;那單向循環鏈表就是不指向為NULL了&#xff0c;指向頭節點&#xff0c;所以下面這個程序運行結果就是&#xff0c;你將會看到遍歷…

web服務器原理

什么是web服務器&#xff1f; 在Mosaic瀏覽器&#xff08;通常被認為是第一個圖形化的web瀏覽器&#xff09;和超鏈接內容的初期&#xff0c;演變出了“web服務器”的新概念&#xff0c;它通過HTTP協議來提供靜態頁面內容和圖片服務。在那個時候&#xff0c;大多數內容都是靜態…

(C語言版)鏈表(三)——實現雙向鏈表創建、刪除、插入、釋放內存等簡單操作

http://blog.csdn.net/fisherwan/article/details/19760681 上午寫了下單向循環鏈表的程序&#xff0c;今天下午我把雙向鏈表的程序寫完了。其實雙向鏈表和單向鏈表也是有很多相似的地方的&#xff0c;聽名字可以猜到&#xff0c;每個節點都包含兩個指針&#xff0c;一個指針指…

競態條件

pause函數 調用該函數可以造成進程主動掛起&#xff0c;等待信號喚醒。調用該系統調用的進程將處于阻塞狀態(主動放棄cpu) 直到有信號遞達將其喚醒。 int pause(void); 返回值&#xff1a;-1 并設置errno為EINTR 返回值&#xff1a; ① 如果信號的默認處理動作是終止進程&#…

(C++版)鏈表(一)——實現單向鏈表創建、插入、刪除等相關操作

http://blog.csdn.net/fisherwan/article/details/25557545 前段時間用C語言實現了鏈表的相關操作&#xff0c;但是發現當時挺清楚的&#xff0c;過了一段時間又忘的差不多了&#xff0c;所以現在打算用C再實現一遍&#xff0c;由于初次用C實現&#xff0c;存在錯誤的地方還望大…

(C語言版)鏈表(二)——實現單向循環鏈表創建、插入、刪除、釋放內存等簡單操作

http://blog.csdn.net/fisherwan/article/details/19754585 昨天寫了單向鏈表的代碼&#xff0c;今天上午把單向循環鏈表的程序給敲完了。鏈表的相關操作一樣的&#xff0c;包含鏈表的創建、判斷鏈表是否為空、計算鏈表長度、向鏈表中插入節點、從鏈表中刪除節點、刪除整個鏈表…

計科院首頁靜態網頁

一.HTML代碼 <!DOCTYPE html><html><head><meta charset"UTF-8"><title>首頁</title> </head><body><div id"page"> <div id"page_head"> <div id"logo" aligncenter…

可重入函數

一個函數在被調用執行期間(尚未調用結束)&#xff0c;由于某種時序又被重復調用&#xff0c;稱之為“重入”。根據函數實現的方法可分為“可重入函數”和“不可重入函數”兩種。 注意事項 定義可重入函數&#xff0c;函數內不能含有全局變量及static變量&#xff0c;不能使用ma…

(C語言版)鏈表(四)——實現雙向循環鏈表創建、插入、刪除、釋放內存等簡單操作

http://blog.csdn.net/fisherwan/article/details/19801993 雙向循環鏈表是基于雙向鏈表的基礎上實現的&#xff0c;和雙向鏈表的操作差不多&#xff0c;唯一的區別就是它是個循環的鏈表&#xff0c;通過每個節點的兩個指針把它們扣在一起組成一個環狀。所以呢&#xff0c;每個…