在linux下,通过open打开以文件后,会返回一个文件描述符,文件描述符会指向一个文件表,文件表中的节点指针会指向节点表。看下图:
​​​​​​
dup和dup2两个函数都可以用来复制打开的文件描述符,复制成功后和复制源共享同一个文件表:

​​​​

dup()函数:
#include
#include
int main(int argc, char *argc[])
{
  int fd;
  fd = open("test.txt",O_RDWR);
  printf("%d\n",fd);
  close(fd);
  return 0;
}

运行以上代码,执行成功的话,应当是输出3,因为0,1,2分别被标准输入,标准输出,标准错误输出占用了。使用dup复制这个文件描述符,并尝试移动fd偏移量:
​​​​
编译执行上例代码可以发现当移动fd的偏移量时,fd2的偏移量也发生了变化。往文件里写入内容试试,先把test.txt内容清空。

​​​​

编译执行程序,test.txt的就有hello world!字符串了。

dup2()函数:
dup2和dup函数一样,只是返回的文件描述符可以通过第二个参数”可用的文件描述符“指定。如果“可用的文件描述符“是打开状态,则会被关闭;如果”现存的文件描述符“和”可用的文件描述符“一样的话,代码是没有任何意义的,并且会导致错误。​​​

上面程序就是指定返回的文件描述为100,再来看下指定的文件描述符是打开的情况,修改上例代码,将文件描述符指定为1:

fd2=dup2(fd,1);

编译执行程序将看不到任何输出,因为1是终端标准输出的标识符,经过这样一复制后,标准输出就被关闭了,使用printf自然看不到输出信息了。