学习,记录。

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掉,
返回该描述符。

注释挺详细,看注释吧

执行结果:

  1. //Code by Pnig0s1992 
  2. //Date:2012,3,28 
  3. #include <unistd.h> 
  4. #include <fcntl.h> 
  5. #include <string.h> 
  6. #include <sys/types.h> 
  7. #include <sys/stat.h> 
  8.  
  9.  
  10. int my_dup(int olddup,int newdup); 
  11.  
  12. int main(int argc,char ** argv) 
  13.     int newdup = 3; 
  14.     const char * filename = "newfile.txt"
  15.     int fd = open(filename,O_RDWR); 
  16.     int newfd = my_dup(fd,newdup); 
  17.     if(write(newfd,"Test new fd.",strlen("Test new fd.")) < 0) 
  18.     { 
  19.         printf("Use new fd write file failed."); 
  20.         exit(2); 
  21.     }else 
  22.     { 
  23.         printf("Write successfully."); 
  24.     } 
  25.     exit(0); 
  26.  
  27. int my_dup(int olddup,int newdup) 
  28.     int tempdup; 
  29.     int icount = 0; 
  30.     int filedesarr[newdup]; 
  31.     if((tempdup = dup(olddup)) == -1) //判断原文件描述服是否有效 
  32.     { 
  33.         printf("the file desp is invalid."); 
  34.         exit(1); 
  35.     }else 
  36.     { 
  37.         close(tempdup); 
  38.     } 
  39.  
  40.     if(newdup == olddup) //若新旧文件描述符相等则直接返回 
  41.     { 
  42.         return olddup; 
  43.     } 
  44.     close(newdup);//关闭要复制的文件描述符 
  45.     for(icount = 0;icount<newdup+1;icount++) //循环复制文件描述符 
  46.     { 
  47.         filedesarr[icount] = 0; 
  48.         tempdup = dup(newdup); 
  49.         if(tempdup < 0) 
  50.         { 
  51.             return -1; 
  52.         }else 
  53.         { 
  54.             if(tempdup == newdup) 
  55.             { //若复制后的文件描述符于指定的相等则跳出 
  56.                 break
  57.             }else
  58.                 filedesarr[icount] = 1; //否则将对应下标的数组元素置为1 
  59.             } 
  60.         } 
  61.     } 
  62.     for(icount = 0;icount<newdup+1;icount++) //关闭之前打开的非指定描述符 
  63.     { 
  64.         if(filedesarr[icount] == 1) 
  65.         { 
  66.             close(icount); 
  67.         } 
  68.     } 
  69.     return tempdup;