Wednesday, January 26, 2011

Linux dup()\dup2()函数-實例

Linux dup()\dup2()函数

[日期:2010-12-12] 来源:Linux社区  作者:Linux
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); //打开文件操作 【6688电子商务网站 www.6688.cc 】
    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 );   /* "old" now refers to "stdout" */
                      /* Note: file handle 1 == "stdout" */
   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 );
   }
   /* stdout now refers to file "data" */
   if( -1 == _dup2( _fileno( new ), 1 ) )
   {
      perror( "Can't _dup2 stdout" );
      exit( 1 );
   }
   puts( "This goes to file 'data'\r\n" );
   /* Flush stdout stream buffer so it goes to correct file */
   fflush( stdout );
   fclose( new );
   /* Restore original stdout */
   _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'

1 comment: