在类Unix操作系统里面,。dup2和dup都通过系统调用来产生一份file descriptor 的拷贝。
 
   dup对我来说还很简单
 
   int dup(int filedes);
 
   dup2就有点犯迷糊了
 
   int dup2(int filedes1,int filedes2);
 
   其实这样declaration更好
 
   int dup2(int oldfd,int newfd)
 
   下面是apue给出的解释
 
   With dup2, we specify the value of the new descriptor with the fd2 argument.
 
   If fd2 is already open, it is first closed. If fd equals fd2,t hen dup2 re turns fd2 without closing it.
 
   Otherwise, theFD_CLOEXECfile descriptor flag is cleared forfd2, so that fd2 is left open if the process calls exec
 
   我就比较疑惑,如果newfd是STDIN_FILENO,STDOUT_FILENO,STDERR_FILENO,(0,1,2)三个中的一个呢?
 
   dup2是返回错误还是 “fd2 is already open, it is first closed”呢?
 
   Just test it.
 
   #include
 
   #include"fcntl.h"
 
   #include
 
   int main()
 
   {
 
   int file_descriptor;
 
   if((file_descriptor = open("./text.t",O_RDWR)) < 0)
 
   {
 
   printf("error\n");
 
   }
 
   else
 
   {
 
   printf("file descriptor is %d\n",file_descriptor);
 
   }
 
   printf("dup2 return value:%d\n dup return value\
 
   %d\n",dup2(file_descriptor,0),dup(file_descriptor));
 
   printf("dup2 return value:%d\ndup return value\
 
   %d\n",dup2(file_descriptor,1),dup(file_descriptor));
 
   printf("dup2 return value:%d\ndup return value\
 
   %d\n",dup2(file_descriptor,2),dup(file_descriptor));
 
   close(file_descriptor);
 
   return 0;
 
   }
 
   Aha! Something interesting happened.
 
   运行结果:
 
   file descriptor is 3
 
   dup2 return value:0
 
   dup return value 4
 
   以上就是这段code的运行结果。嗯。。。我有三个printf语句,为啥米只答应了第一个,WTF。。。
 
   问题都在第二个printf语句中调用的dup2 www.jx-jf.com
 
   dup2的第二个参数是1,1是什么?STDIN_FILENO宏的本质就是1.这里还是那句话“fd2 is already open, it is first closed”
 
   三个标准流在文件进程开始的时候肯定是都被打开的,already open是一定的事情 www.yzyedu.com
 
   So。。。dup2非常“老实本分"的把STDOUT_FILENO在第二printf的时候关闭了
 
   这个时候printf的输出就不会被打印在标准输出设备上面了,因为STDOUT_FILENO已经被关闭了!!
 
   如果这个时候只要把第二个printf里面dup2的第二个参数改成大于2的数字就没事了。
 
   code:
 
   #include
 
   #include"fcntl.h"
 
   #include
 
   int main()
 
   {
 
   int file_descriptor;
 
   if((file_descriptor = open("./text.t",O_RDWR)) < 0)
 
   {
 
   printf("error\n");
 
   }
 
   else
 
   {
 
   printf("file descriptor is %d\n",file_descriptor);
 
   }
 
   printf("dup2 return value:%d\n dup return value\
 
   %d\n",dup2(file_descriptor,0),dup(file_descriptor));
 
   printf("dup2 return value:%d\ndup return value\
 
   %d\n",dup2(file_descriptor,10),dup(file_descriptor));
 
   printf("dup2 return value:%d\ndup return value\
 
   %d\n",dup2(file_descriptor,11),dup(file_descriptor));
 
   close(file_descriptor);
 
   return 0;
 
   }
 
   运行结果:
 
   file descriptor is 3
 
   dup2 return value:0
 
   dup return value 4
 
   dup2 return value:10
 
   dup return value 5
 
   dup2 return value:11
 
   dup return value 6
 
   这个时候就很清楚了。
 
   Similarly,the call
 
   dup2(fd, fd2);
 
   is equivalent to
 
   close(fd2);
 
   fcntl(fd, F_DUPFD, fd2);
 
   当然也不完全相同,不同点如下:
 
   1. dup2 is an atomic operation, whereas the alternate form involves two function
 
   calls. It is possible in the latter case to have a signal catcher called between the
 
   closeand the fcntlthat could modify the file descriptors. (W edescribe
 
   signals in Chapter 10.) The same problem could occur if a different thread
 
   changes the file descriptors. (Wedescribe threads in Chapter 11.)
 
   2. Ther eare s ome errnodifferences between dup2 and fcntl.

用dup2和dup产生一份file descriptor 的拷贝的更多相关文章

  1. 文件描述符file descriptor与inode的相关知识

    每个进程在Linux内核中都有一个task_struct结构体来维护进程相关的 信息,称为进程描述符(Process Descriptor),而在操作系统理论中称为进程控制块 (PCB,Process ...

  2. [svc]linux中的文件描述符(file descriptor)和文件

    linux中的文件描述符(file descriptor)和文件 linux为了实现一切皆文件的设计哲学,不仅将数据抽象成了文件,也将一切操作和资源抽象成了文件,比如说硬件设备,socket,磁盘,进 ...

  3. 近期编程问题——epoll failed:bad file descriptor

    出现问题:epoll_wait:Bad file descriptor 原因:IO时间的socket描述符在epoll_ctl处理前就关闭了. 解决方法:不要在epoll_ctl之前关闭socket描 ...

  4. mongodb在ubuntu下的couldn‘t remove fs lock errno:9 Bad file descriptor的错误

    按照官网上的安装方法: 在ubuntu系统下有可能出现如下错误: couldn't remove fs lock errno:9 Bad file descriptor 此时需要修改文件所有者 $ s ...

  5. shell 中最常使用的 FD (file descriptor)

    在 shell 程式中,最常使用的 FD (file descriptor) 大概有三个, 分别是: 0 是一个文件描述符,表示标准输入(stdin)1 是一个文件描述符,表示标准输出(stdout) ...

  6. python print 在windows上 出现 Bad file descriptor error

    先说一下情况,一个python写的采集程序,做成windows服务在windows上运行. 这个问题出现的挺奇特,本来一套采集程序,一个采集文件的时候没问题,两个采集文件的时候也没问题,当三个采集文件 ...

  7. windows pm2 启动nodejs失败:Error: EBADF: bad file descriptor, uv_pipe_open

    windows下打开命令窗口,安装pm2:npm install pm2 -g pm2成功安装,在项目目录下用pm2启动服务:pm2 start index.js,结果启动失败,错误如下: .pm2\ ...

  8. fastDFS errcode:9 path:Bad file descriptor errcode:22 path:Invalid argument

    fastDFS errcode:9 path:Bad file descriptor errcode:22 path:Invalid argument <error>status:4 er ...

  9. dpdk EAL: Error reading from file descriptor 23: Input/output error

    执行test程序时输出: EAL: Error reading from file descriptor 23: Input/output error 原因: 在虚拟机添加的网卡,dpdk不支持导致的 ...

随机推荐

  1. COJ 3016 WZJ的图论问题

    传送门:http://oj.cnuschool.org.cn/oj/home/problem.htm?problemID=1046 试题描述: WZJ又有一个问题想问问大家.WZJ用数据生成器生成了一 ...

  2. 【转】Android进阶2之Activity之间数据交流(onActivityResult的用法)----不错

    原文网址:http://blog.csdn.net/sjf0115/article/details/7387467 主要功能: 在一个主界面(主Activity)上能连接往许多不同子功能模块(子Act ...

  3. HDOJ 2114 Calculate S(n)(找周期)

    Problem Description Calculate S(n). S(n)=1^3+2^3 +3^3 +--+n^3 . Input Each line will contain one int ...

  4. [git] github 使用简单记录

    前提 :1. 已有 github 账号.2. 已安装 git .3. 在 github 和 本地 git 客户端交互秘钥.(这步我记得需要做,有点久远,不确定.) 正文: 下面是一个简单的例子.先在 ...

  5. IT码农哥放弃50万年薪:辞职卖咖喱凉皮(背后深藏功与名)_互联网的一些事

    IT码农哥放弃50万年薪:辞职卖咖喱凉皮(背后深藏功与名)_互联网的一些事 IT码农哥放弃50万年薪:辞职卖咖喱凉皮(背后深藏功与名)

  6. P - 奔小康赚大钱 - hdu 2255(带权值的匹配)

    分析:这是一个KM的模板题,也就不多说了,KM最复杂的情况都能过,下面是没有优化过的代码: ****************************************************** ...

  7. 只有20行Javascript代码!手把手教你写一个页面模板引擎

    http://www.toobug.net/article/how_to_design_front_end_template_engine.html http://barretlee.com/webs ...

  8. ASP.NET MVC框架开发系列课程 (webcast视频下载)

    课程讲师: 赵劼 MSDN特邀讲师 赵劼(网名“老赵”.英文名“Jeffrey Zhao”,技术博客为http://jeffreyzhao.cnblogs.com),微软最有价值专家(ASP.NET ...

  9. 线段树---HDU1394Minimum Inversion Number

    此题和上题略有不同,但是大体差不多,不过要把题意转换过来,题目大体意思为, 输入n, 也就是n个数,这些数为0 - (n-1), 这些数刚开始给定输入的顺序, 然后求他的逆序数,然后接着把第一个移到这 ...

  10. 8、第八次课jquery第一节20151006

    1.JS JQUERY 的区别 jquery 底层基于js 它是对于JS进行封装,代码量比较少.[write less do more] 网上可以下载jquery 类库文件,写的时候需要智能提示在js ...