Перенаправить стандартный вывод обратно в консоль - PullRequest
0 голосов
/ 10 октября 2018

Существует множество документов по перенаправлению stdout и stderr в файл вместо консоли.Как вы перенаправите его обратно?Приведенный ниже код показывает мое намерение, но выводит «stdout выводится на консоль» только один раз.

Я предполагаю, что мне нужно захватить буфер вывода консоли, сохранить его где-то, перенаправить stdout в файл, а затем восстановитьконсольный буфер?

#pragma warning(disable:4996)

#include <cstdio>

int main()
{
    std::printf("stdout is printed to console\n");

    if (std::freopen("redir.txt", "w", stdout)) {
        std::printf("stdout is redirected to a file\n"); // this is written to redir.txt
        std::fclose(stdout);

        std::printf("stdout is printed to console\n");
    }

    getchar();
    return 0;
}

1 Ответ

0 голосов
/ 10 октября 2018

Благодаря статьям в комментариях выше я нашел нужную информацию.Функции dup и dup2 были тем, что мне было нужно.Обратите внимание, что на основании информации здесь dup и dup2 устарели в пользу _dup и _dup2.Рабочий пример можно найти на MSDN здесь , но он дублируется ниже на случай разрыва связи в будущем.

// crt_dup.c
// This program uses the variable old to save
// the original stdout. It then opens a new file named
// DataFile and forces stdout to refer to it. Finally, it
// restores stdout to its original state.

#include <io.h>
#include <stdlib.h>
#include <stdio.h>

int main( void )
{
   int old;
   FILE *DataFile;

   old = _dup( 1 );   // "old" now refers to "stdout"
                      // Note:  file descriptor 1 == "stdout"
   if( old == -1 )
   {
      perror( "_dup( 1 ) failure" );
      exit( 1 );
   }
   _write( old, "This goes to stdout first\n", 26 );
   if( fopen_s( &DataFile, "data", "w" ) != 0 )
   {
      puts( "Can't open file 'data'\n" );
      exit( 1 );
   }

   // stdout now refers to file "data"
   if( -1 == _dup2( _fileno( DataFile ), 1 ) )
   {
      perror( "Can't _dup2 stdout" );
      exit( 1 );
   }
   puts( "This goes to file 'data'\n" );

   // Flush stdout stream buffer so it goes to correct file
   fflush( stdout );
   fclose( DataFile );

   // Restore original stdout
   _dup2( old, 1 );
   puts( "This goes to stdout\n" );
   puts( "The file 'data' contains:" );
   _flushall();
   system( "type data" );
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...