我正在使用boost daytime示例作为项目的启动器,需要在机器之间进行双向通信,现在需要在自己的线程中启动asio io_service,以便我可以跨seperatley传递数据。以下是我的代码的基础:http://www.boost.org/doc/libs/1_35_0/doc/html/boost_asio/tutorial/tutdaytime7/src.html
如果我使用
调用main中的服务,一切正常io_service.run()
但是,如果我尝试创建一个线程组并在那里启动:
int main()
{
boost::thread_group tgroup;
try
{
boost::asio::io_service io_service;
tcp_server server1(io_service);
udp_server server2(io_service);
tgroup.create_thread(boost::bind(&boost::asio::io_service::run, &io_service));
std::cout << "Server running on TCP port " << tcpport << std::endl << "Server running on UDP port " << udpport << std::endl;
}
catch (std::exception& e)
{
std::cerr << e.what() << std::endl;
}
tgroup.join_all();
return 0;
}
代码编译并运行,端口号由cout正确引用,但它似乎没有打开监听端口,因为客户端拒绝连接,尽管服务器程序似乎正在等待连接。
请问这里发生了什么?
答案 0 :(得分:2)
我的猜测是,如果您将tgroup.join_all();
放在catch
之前,您的代码就会有效:
...
try {
boost::asio::io_service io_service;
tcp_server server1(io_service);
udp_server server2(io_service);
tgroup.create_thread(boost::bind(&boost::asio::io_service::run, &io_service));
std::cout << "Server running on TCP port " << tcpport << std::endl << "Server running on UDP port " << udpport << std::endl;
tgroup.join_all();
}
...
io_service
和服务器对象在这里超出范围并被销毁,可能在线程组的线程开始运行之前。