1

我正在尝试使用stderr,但我对它的用法完全感到困惑。我正要回答这里提出的一个问题,但是当我想先尝试一下时,我发现自己陷入了困境。

我在此链接中阅读了有关stderr的信息,并且根据我尝试像这样使用它的信息

FILE *stderr;

stderr = fopen("<path to file>","w");

.....//some code and conditions
fprintf(stderr,"found a error here");

使用它会给我一个段错误,我无法弄清楚为什么?

然后我使用了freopen(),然后我也得到了 seg 错误。stderr 本身是否将标准错误发送到某个默认文件而不是标准输出。

这是我的代码,我只是尝试将 stderr 用作任何其他 FILE * 指针。我可能完全把它当作错误的执行方式。或者它只将标准编译器错误写入某些默认文件。需要帮助。

#include<stdio.h>
#include<string.h>
#include<time.h>
FILE *stderr;

int main()
{
time_t start,end;
volatile long unsigned counter;
start = time(NULL);
for(counter = 0; counter < 500000000; counter++)
{}

int i;
char str1[]="XXXXXXX-XXXXXXXXX-YYYYYYYY-TTTTTT";
char str2[]="pro1_0.0";
char str3[]="CC";
char str4[]="ZZ";
char str5[]="QQ";
char serialstring[100];
stderr = fopen("path to file","w");
//freopen("llog.out","w",stderr);

printf("enter a serial string:");
scanf("%s",serialstring);
if((strstr(serialstring,str1)))
{
printf("String1  matched\n");
  if((strstr(serialstring,str2)))
   {
   fprintf(stderr,"str2 matched\n"); //it is where i tried using fprintf and stderr, rest of code is working pretty file 
      if((strstr(serialstring,str3)))
       {
          printf("str3 matched\n");
         }
      else if((strstr(serialstring,str4)))
           {printf("str4 matched\n");}
      else if((strstr(serialstring,str5)))
           {printf("str5 matched\n");
for(i=232;i<290;i++)
{
printf("Sending some values: %d\n",i);}}
    }
   else{printf("str2 not matched\n");}
}
else{printf("str1 not matched\n");}

end = time(NULL);
        printf("The loop used %f seconds.\n", difftime(end, start));
        return 0;
}
4

2 回答 2

6

你不应该试图超越stderr自己。就用它吧。它由运行您的程序的程序提供给您。如果您的程序是从终端上的 shell 以交互方式运行的,那么两者stdout通常stderr都会转到终端,但是有很多方法可以被覆盖。它被覆盖的最常见方式是调用者已重定向stdout到文件以保存输出,但仍stderr连接到终端,以便用户可以看到状态/错误消息。

于 2013-09-27T06:57:20.733 回答
1

使用dup2()

int fd = open("mylog.txt", O_RDWR | O_APPEND | O_CREAT);
if (fd < 0) {
     printf("Cannot open mylog.txt!\n");
     exit(1);
}
if (dup2(fd, STDERR_FILENO) < 0) {
     printf("Cannot redirect stderr!\n");
     exit(1);
}

从此时起,任何对 stderr 的写入都将转到"mylog.txt".

您也可以使用类似的方法进行重定向stdout- 只需使用STDOUT_FILENO.

于 2013-09-27T07:13:05.737 回答