gpt4 book ai didi

c++ - Boost Asio延迟写入tcp套接字

转载 作者:行者123 更新时间:2023-11-28 05:41:46 26 4
gpt4 key购买 nike

我有一个简单的 TCP 服务器,它有一个带 asio 循环的线程,还有一个线程池来进行计算。我能够听到连接在主线程中向其写入内容。但我等不及工作线程的回答,因为连接在被接受后立即关闭。

我尝试使用截止时间计时器,但由于某种原因它会立即被调用并出现“中止操作”错误。

我要实现的整个过程是:

  • 接受连接
  • 写点东西
  • 向工作池发送任务
  • 等待工作人员的回答(我正在使用线程安全队列从工作人员池中读取消息)
  • 将答案写入socket
  • 关闭连接

这是我的代码

class tcp_connection
: public boost::enable_shared_from_this<tcp_connection>
{
public:
typedef boost::shared_ptr<tcp_connection> pointer;

static pointer create(boost::asio::io_service& io_service)
{
return pointer(new tcp_connection(io_service));
}

tcp::socket& socket()
{
return socket_;
}

void start()
{
message_ = "Write me in 5 sec";
boost::asio::deadline_timer t(service_, boost::posix_time::seconds(5));
t.async_wait(boost::bind(&tcp_connection::writeAfter, shared_from_this(), boost::asio::placeholders::error));
}

private:
tcp_connection(boost::asio::io_service& io_service)
: service_(io_service), socket_(io_service)
{
}

void writeAfter(const boost::system::error_code&) {
std::cout << "writing to socket" << std::endl;
boost::asio::async_write(socket_, boost::asio::buffer(message_),
boost::bind(&tcp_connection::handle_write, shared_from_this(),
boost::asio::placeholders::error,
boost::asio::placeholders::bytes_transferred));
}


void handle_write(const boost::system::error_code& /*error*/,
size_t /*bytes_transferred*/)
{
}

boost::asio::io_service &service_;
tcp::socket socket_;
std::string message_;
};

编辑:调试日志

@asio|1462018696.996630|0*1|deadline_timer@0x7ffd9dd40228.async_wait
@asio|1462018696.996675|0|deadline_timer@0x7ffd9dd40228.cancel
@asio|1462018696.996694|0*2|socket@0x7ffd9dd403e0.async_accept
@asio|1462018696.996714|0*3|deadline_timer@0x7ffd9dd40408.async_wait
@asio|1462018696.996736|>1|ec=system:125

正如我们所看到的,取消是在计时器上调用的,但我的代码中没有一个取消,所以我不知道为什么要调用它。

非常感谢您的帮助

最佳答案

创建 tcp_connection 后,您是否仍在监听其他连接?

由于您尚未为新连接调用 async_readasync_read_some,因此该线程的 io_service.run() 可能已经完成...

如果您在 tcp_connection 构造函数中启动 deadline timer,它应该保持 io_service.run() 运行并发送消息。

关于c++ - Boost Asio延迟写入tcp套接字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36953581/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com