在学习《UNIX环境高级编程》的时候,可能是由于对UNIX的基础及设计哲学了解得不够深,在学到第三章的dup及dup2函数时感觉理解有点吃力。
我的理解如下:
函数原型:
#include<unistd.h>
int dup(int filedes);
int dup2(int filedes,int filedes2);
这两个函数的功能都是用来复制一个现存的文件描述符。
一、dup函数
dup函数的功能是复制现存的文件描述符filedes到一个新文件描述符,新文件描述符由函数还回(函数出错还回-1)。函数还回的新文件描述符与参数filedes共享一个文件表项。假设图1是原始的内核数据结构情况。
注:由dup还回的文件描述符一定是当前可用文件描述符中的最小数值。
图1 dup(1)前内核数据结构
在此图中,假设我们执行了:
newfd=dup(1);
当此函数开始执行时,假定下一个可用的文件描述符是3,则执行后内核数据结构情况如图2。
图2 dup(1)前内核数据结构
二、dup2函数
用dup2则可以用filedes2参数指定新描述符的数值。如果filedes2已经打开,则先将其关闭。如若filedes等于filedes2,则
dup2返回filedes2,而不关闭它。
假设图3是原始的内核数据结构情况。
图3 dup2(3,STDOUT_FILENO)前内核数据结构
在此图中,假设我们执行了:
newfd=dup2(3,STDOUT_FILENO);
则执行后内核数据结构情况如图4。
图4 dup2(3,STDOUT_FILENO)后内核数据结构
上述图示应该能很好反映这两个函数的执行情况。
参考:
1): 《UNIX环境高级编程》W.Richard Stevens
2):http://read.newbooks.com.cn/info/50266.html