每当发生这种情况时,我正在使用boost::process::child
并boost::process::async_pipe
启动一个应用程序并异步(通过boost::asio
)读取应用程序在屏幕上输出的所有内容。
我还想通过使用child::running()
方法检查应用程序是否还活着;如果没有运行,我想使用child::exit_code
.
这非常有用,特别是因为它是一种通知应用程序崩溃或意外退出的方法(我找不到更好的方法);当应用程序退出时,使用boost::system::error_code
set 调用回调。
你知道我是否可以在调用的回调中使用这两种方法async_pipe::async_read_some
吗?
一般来说,更简单的问题是线程是否安全(在 Windows 和 Linux 中)child::running()
。child::exit_code()
namespace bp = boost::process;
char my_buffer[1024];
boost::asio::io_service io;
bp::async_pipe in_pipe(io);
void handle_pipe_read(const boost::system::error_code &ec, std::size_t bytes_transferred);
void schedule_read() {
in_pipe.async_read_some(
boost::asio::buffer(my_buffer),
boost::bind(&handle_pipe_read,
boost::asio::placeholders::error,
boost::asio::placeholders::bytes_transferred));
}
void handle_pipe_read(
const boost::system::error_code &ec,
std::size_t bytes_transferred
)
{
// Q: Is this call possible? 'handle_pipe_read' can run in any thread
if(c->running())
std::cout << "I am alive" << std::endl;
else
std::cout << "EXIT CODE:" << c->exit_code() << std::endl;
if(ec) return; //app probably exit
// Do something with buffer and re-schedule
schedule_read();
}
int main() {
bp::child c("my_program_url", bp::std_out > in_pipe);
any_c = &c;
schedule_read();
io.run();
}