1

我有以下代码,它是从我试图在连接到子进程的 async_pipe 上执行 async_read 的真实代码中简化而来的。在子进程中,我称之为“ls”。作为一个测试,我希望我的异步读取能够得到结果。它返回以下内容

$ ./a.out
system:0
0

为什么会发生这种情况我无法弄清楚?理想情况下,我想替换“ls”。有一个长时间运行的过程,我可以用 async_read 逐行读取。

#include <boost/asio.hpp>
#include <boost/bind.hpp>
#include <iostream>
#include <fstream>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <boost/process.hpp>

namespace bp = boost::process;

class test {
private:
  boost::asio::io_service ios;
  boost::asio::io_service::work work;
  bp::async_pipe ap;
  std::vector<char> buf;

public:
  test()
    : ios(), work(ios), ap(ios) {
  }

  void read(
      const boost::system::error_code& ec,
      std::size_t size) {
    std::cout << ec << std::endl;
    std::cout << size << std::endl;
  }

  void run() {
    bp::child c(bp::search_path("ls"), ".", bp::std_out > ap);
    boost::asio::async_read(ap, boost::asio::buffer(buf),
      boost::bind(&test::read,
                  this,
                  boost::asio::placeholders::error,
                  boost::asio::placeholders::bytes_transferred));

    ios.run();
  }
};

int main() {
  test c;
  c.run();
}
4

1 回答 1

2

你读入一个大小为 0 的向量。

你读了 0 个字节。这就是你要求的。

我建议使用 streambuf 并一直阅读到 EOF。另外,work除非你真的不想run()再回来,否则放弃:

Live On Coliru

#include <boost/asio.hpp>
#include <boost/bind.hpp>
#include <boost/process.hpp>
#include <iostream>

namespace bp = boost::process;

class test {
  private:
    boost::asio::io_service ios;
    bp::async_pipe ap;
    boost::asio::streambuf buf;

  public:
    test() : ios(), ap(ios) {}

    void read(const boost::system::error_code &ec, std::size_t size) {
        std::cout << ec.message() << "\n";
        std::cout << size << "\n";
        std::cout << &buf << std::flush;
    }

    void run() {
        bp::child c(bp::search_path("ls"), ".", bp::std_out > ap, ios);

        async_read(ap, buf, boost::bind(&test::read, this, _1, _2));

        ios.run();
    }
};

int main() {
    test c;
    c.run();
}

印刷品,例如

End of file
15
a.out
main.cpp
于 2017-12-03T15:29:00.413 回答