dup函数的作用:复制一个现有的句柄,产生一个与“源句柄特性”完全一样的新句柄(也即生成一个新的句柄号,并关联到同一个设备)
dup2函数的作用:复制一个现有的句柄到另一个句柄上,目标句柄的特性与“源句柄特性”完全一样(也即首先关闭目标句柄,与设备断连,接着从源句柄完全拷贝复制到目标句柄)
dup和dup2都是系统服务,window平台对应DuplicateHandle函数 这两个函数常用于输出的重定向,定义这两个函数的头文件是unistd.h。 要提的是这个头文件同时定义了下面三个常量:STDERR_FILENO = 2 标准错误输出STDIN_FILENO = 0 标准输入STDOUT_FILENO = 1 标准输出
int fd, fd2;
mode_t fd_mode = S_IRUSR|S_IWUSR|S_IRGRP|S_IROTH;void redir_stdout(const char *filename)
{ fd2=dup(STDOUT_FILENO); fd = open(filename, O_WRONLY|O_CREAT, fd_mode); //打开文件操作 dup2(fd, STDOUT_FILENO); //把输出重定向到fd标识的文件 close(fd);}fd2=dup(STDOUT_FILENO);说明fd2表示了标准输出
如果我们想把刚刚定向到fd的输出,再定向回标准输出,我们可以用下面的代码实现: void resume_stdout() //恢复输出,把标准输出定向到fd2,fd2代表的是标准输出{ dup2(fd2, STDOUT_FILENO); close(fd2);} #i nclude <io.h>#i nclude <stdlib.h>#i nclude <stdio.h>void main( void )
{ int old; FILE *new;old = _dup( 1 );
if( old == -1 ) { perror( "_dup( 1 ) failure" ); exit( 1 ); } write( old, "This goes to stdout first\r\n", 27 ); if( ( new = fopen( "data", "w" ) ) == NULL ) { puts( "Can't open file 'data'\n" ); exit( 1 ); }if( -1 == _dup2( _fileno( new ), 1 ) ) { perror( "Can't _dup2 stdout" ); exit( 1 ); } puts( "This goes to file 'data'\r\n" );
fflush( stdout ); fclose( new );
_dup2( old, 1 ); puts( "This goes to stdout\n" ); puts( "The file 'data' contains:" ); system( "type data" );} Output
This goes to stdout first
This goes to file 'data'This goes to stdout
The file 'data' contains:
This goes to file 'data'