在NAO上叉,执行和管道

时间:2014-09-18 08:39:49

标签: c++ pipe nao-robot

我目前在Aldebaran的NAO上编程,我需要从C ++代码执行shell命令,然后在缓冲区中取回输出。我使用了fork,execve和pipe的经典方法,但是,正是当我在NAO模块中测试它时,管道不起作用。我的意思是,终端中写入的命令没有输出,但父进程中的read()等待STDIN。

真正奇怪的是,如果我只是做一个简单的程序来测试分支和管道,执行完全相同的命令,管道就可以工作。

更奇怪的是,写(1," HERE \ n",5)已正确执行,并且read()会收回消息;

我的结论是,在C ++ NAO模块中,dup2()在子进程中工作,但在父进程中不工作。

你们有什么可能的问题吗?

以下是代码:

void
Sonar::getResult()
{
  int pfd[2];
  char buf[4] = { 0, 0, 0, 0 };
  char *arg[] = { "/home/nao/picocom", "-b", "9600", "dev/ttyUSB0", 0 };
  int pid = 0;

  pipe(pfd);

  if ((pid = fork()) == 0)
  {
    close(pfd[0]);
    dup2(pfd[1], 1);

    write(1, "HERE\n", 5);
    int ret = execve(arg[0], arg, 0);

    if (ret == -1)
    {
      close(pfd[1]);
      write(1, "Fail.\n", 6);
      kill(getpid(), 15);
    }
  }

  std::cout << "Pid : " << pid << std::endl;

  close(pfd[1]);
  dup2(pfd[0], 0);
  waitpid(pid, 0, 0);
  int r = read(0, buf, 3);
  close(pfd[0]);

  std::cout << "Read : " << r << std::endl;

  printResult(buf);
}

1 个答案:

答案 0 :(得分:0)

您应该使用qi::os::spawnvp在NAO上生成进程。顺便说一下,它是跨平台的。 qi::os函数可以在NAOqi SDK中提供的包含<qi/os.hpp>中找到,也可以直接在libqi中找到,并且非常有用,甚至超出了NAO。