學習,記錄。
int dup2(int oldhandle, int newhandle);
函數功能:
復制文件句柄,newhandle指定的dup2和dup的區別就是可以用newfd參數指定新描述符的數值,如果newfd已經打開,則先將其關閉。如果newfd等於oldfd,則dup2返回newfd, 而不關閉它。dup2函數返回的新文件描述符同樣與參數oldfd共享同一文件表項。
關鍵部分實現思路:
先close關閉需要復制到的文件描述符newdup。
連續dup,每dup一次產生的新的fd記錄下來。
當新產生的fd等於需要產生的fd的時候,跳出循環,並把前面產生的fd全都close掉,返回該描述符。
注釋挺詳細,看注釋吧
執行結果:
//Code by Pnig0s1992 //Date:2012,3,28 #include <unistd.h> #include <fcntl.h> #include <string.h> #include <sys/types.h> #include <sys/stat.h> int my_dup(int olddup,int newdup); int main(int argc,char ** argv) { int newdup = 3; const char * filename = "newfile.txt"; // 本文URL地址:http://www.bianceng.cn/OS/Linux/201410/45509.htm int fd = open(filename,O_RDWR); int newfd = my_dup(fd,newdup); if(write(newfd,"Test new fd.",strlen("Test new fd.")) < 0) { printf("Use new fd write file failed."); exit(2); }else { printf("Write successfully."); } exit(0); } int my_dup(int olddup,int newdup) { int tempdup; int icount = 0; int filedesarr[newdup]; if((tempdup = dup(olddup)) == -1) //判斷原文件描述服是否有效 { printf("the file desp is invalid."); exit(1); }else { close(tempdup); } if(newdup == olddup) //若新舊文件描述符相等則直接返回 { return olddup; } close(newdup);//關閉要復制的文件描述符 for(icount = 0;icount<newdup+1;icount++) //循環復制文件描述符 { filedesarr[icount] = 0; tempdup = dup(newdup); if(tempdup < 0) { return -1; }else { if(tempdup == newdup) { //若復制後的文件描述符於指定的相等則跳出 break; }else{ filedesarr[icount] = 1; //否則將對應下標的數組元素置為1 } } } for(icount = 0;icount<newdup+1;icount++) //關閉之前打開的非指定描述符 { if(filedesarr[icount] == 1) { close(icount); } } return tempdup; }
本文出自 “About:Blank H4cking” 博客,請務必保留此出處http://pnig0s1992.blog.51cto.com/393390/819830