fprintf没有写入管道

时间:2012-04-11 04:23:01

标签: c++ c gnuplot printf

我使用_popen成功打开了管道,即gnuplot窗口。但是无法使用fprintf写入流。我检查了文件指针值,它不是null。我搜索了许多来源并使用fflush并且它无法正常工作。我找不到解决方案。

实际上我在此之前已经问了一个类似的问题gnuplot c++ interface through pipes -cannot open wgnuplot重新进行了一些修改。

任何建议都会有所帮助..

FILE* gp;
  string command = "set style data lines\n" ;
  char *path = "\"C:\\Program Files\\gnuplot\\bin\\wgnuplot\" -persist";

  gp = _popen(path , "wt");

  if (gp == NULL)
    return -1;

 fprintf(gp,command );
 fflush(gp);
 _pclose(gp);

我使用此代码而不使用管道,它使用createprocess。这里也是同样的情况,gnuplot.exe打开但没有输出图。

int _tmain (int argc, LPTSTR argv [])

{
    DWORD i;
    HANDLE hReadPipe, hWritePipe;

    SECURITY_ATTRIBUTES PipeSA = {sizeof (SECURITY_ATTRIBUTES), NULL, TRUE};
            /* Init for inheritable handles. */
    TCHAR outBuf[ ] = TEXT("a=2; plot sin(a*x)/x; pause mouse; plot exp(-a*x); pause mouse") ;  
    TCHAR inBuf[80];
    DWORD dwWritten, dwRead ;
    BOOL  bSuccess = FALSE;
    PROCESS_INFORMATION  ProcInfo2;
    STARTUPINFO StartInfoCh2;


    /* Startup info for the Gnuplot process. */

    GetStartupInfo (&StartInfoCh2);

    /* Create an anonymous pipe with default size.
        The handles are inheritable. */

    bSuccess = CreatePipe (&hReadPipe, &hWritePipe, &PipeSA, 0);
    if (bSuccess == TRUE) printf("pipe created\n");

    WriteFile(hWritePipe, outBuf, sizeof(outBuf), &dwWritten, NULL) ;   
    printf("Wrote %d bytes to Gnuplot\n", dwWritten) ;

    CloseHandle (hWritePipe);

    /* Repeat (symmetrically) for the child process. */

    StartInfoCh2.hStdInput  = hReadPipe;
    StartInfoCh2.hStdError  = GetStdHandle (STD_ERROR_HANDLE);
    StartInfoCh2.hStdOutput = GetStdHandle (STD_OUTPUT_HANDLE);
    StartInfoCh2.dwFlags = STARTF_USESTDHANDLES;
    bSuccess = FALSE ;
    bSuccess = CreateProcess ("C:\\Program Files\\gnuplot\\bin\\wgnuplot.exe", NULL, NULL, NULL,
            TRUE,0, NULL, NULL, &StartInfoCh2, &ProcInfo2);
    if (bSuccess == TRUE)
      printf("Created Gnuplot Process\n" ) ;

    WaitForSingleObject (ProcInfo2.hProcess, INFINITE);
    CloseHandle (ProcInfo2.hThread); 
    CloseHandle (hReadPipe);

    /* Wait for Gnuplot process to complete.*/

    CloseHandle (ProcInfo2.hProcess);
    return 0;
}

2 个答案:

答案 0 :(得分:0)

我认为问题不在于你的代码,而是在Windows上没有做任何事情。这意味着图表永远不会显示超过一瞬间。您可以按照以下方式生成图像,而不是显示gnuplot窗口。

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

int main()
{
  FILE* gp;
  gp = _popen("gnuplot", "w");

  if (gp == NULL)
    return -1;

  fprintf(gp, "set terminal png\nset output 'tmp.png'\n");
  fprintf(gp, "set isosample 100\n");
  fprintf(gp, "min=-1\n");
  fprintf(gp, "max=1\n");
  fprintf(gp, "pi=3.141592\n");
  fprintf(gp, "set hidden3d\n");
  fprintf(gp, "set pm3d\n");
  fprintf(gp, "set contour\n");
  fprintf(gp, "splot [min:max] [min:max] x*x+2*y*y-0.3*cos(3*pi*x)-0.4*cos(4*pi*y)+0.7\n");
  fflush(gp);
  pclose(gp);

  return 0;
}

或者你可以介绍一些等待。

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

int main()
{
  FILE* gp;
  gp = _popen("gnuplot", "w");

  if (gp == NULL)
    return -1;

  fprintf(gp, "set isosample 100\n");
  fprintf(gp, "min=-1\n");
  fprintf(gp, "max=1\n");
  fprintf(gp, "pi=3.141592\n");
  fprintf(gp, "set hidden3d\n");
  fprintf(gp, "set pm3d\n");
  fprintf(gp, "set contour\n");
  fprintf(gp, "splot [min:max] [min:max] x*x+2*y*y-0.3*cos(3*pi*x)-0.4*cos(4*pi*y)+0.7\n");
  fflush(gp);
  for (;;) { }

  return 0;
}

答案 1 :(得分:0)

你对fprintf的语法用法是错误的。 它

fprintf(FILE,"[string literals] [format place holder]",[arguments corresponding to each place holder]);

并且占位符的语法是

%[format type]

表示格式类型,

i or d = int
e = double shown in exponential form
f = double shown in floating point notation
g = double shown in best format
s = char * (a string literal)
c = char

以此为例:

int i=5;
fprintf("i is equal to: %i\n",i);

会输出:

i is equal to 5

\ n是一个显示新行的转义序列。