#include <stdio.h>
#include <stdlib.h>
#define OPEN_MAX 63
int my_dup2(int filedes,int filedes2);
int
main(int argc, char* argv[])
{
int fd,fd2;
char buf[] = "It work!\n";
if(argc != 3)
err_quit("Usage: %s <filedes#> <filedes2#>",argv[0]);
fd = atoi(argv[1]);
fd2 = atoi(argv[2]);
my_dup2(fd, fd2);
printf("fd#%d -> fd#%d\n", fd2, fd);
if( write(fd2, buf, 9) != 9)
err_sys("write error");
exit(0);
}
int
my_dup2(int filedes,int filedes2)
{
int fd_rec[OPEN_MAX];
int fd,i,n;
if( filedes == filedes2) //模拟dup2的行为,当filedes2等于filedes时,直接返回filedes便可
return filedes;
for(n=0 ; (fd=dup(filedes)) < filedes2; n++){ //因为dup总返回当前可用文件描述符的最小值,所以要不断尝试
fd_rec[n] = fd; //保存尝试的文件描述符,以便后面关闭
}
if( fd != filedes2) //退出循环的条件也可能因为filedes2已被占用,这时dup2先将原先占有filedes2的文件关掉,此时dup确定是filedes2
{
close(filedes2);
fd = dup(filedes);
}
//关闭打开的非目标文件描述符
for(i=0; i<n; i++)
close(fd_rec[i]);
return fd;
}
对于my_dup2的测试,linux
$ my_dup2 2 17shell
将在屏幕上输出"It works!";bash
$ my_dup2 7 17 7<>/dev/fd/1函数
也将输出"It works!";测试
$ my_dup2 2 17 17>tmp.fooui
屏幕输出"It words!",但tmp.foo中没有任何记录,这个例子模拟17已被占有的情形。it