APUE习题[实现dup2函数功能,不使用fcntl]


学习,记录。

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

相关内容