c++ - 使用use_future的Boost Asio async_send_to多播不起作用

标签 c++ asynchronous boost boost-asio multicast

ITNOA
我有想要将带有async_send_to的消息发送到一个多播组的程序。但是我想这个 Action 阻止了异步,所以我使用use_future来实现这个目标,如下所示

gw::BoostMessageSender::BoostMessageSender(const std::string& group_address, const std::string& interface_name, uint16_t port_number, ba::io_context& io_context)
    : AbstractMessageSender(group_address, interface_name, port_number)
    , io_context(io_context)
    , endpoint(ba::ip::address::from_string(group_address), port_number)
    , socket(io_context, endpoint.protocol())
{
    if (!socket.is_open())
        socket.open(endpoint.protocol());

    socket.set_option(ba::ip::udp::socket::reuse_address(true));
}

bool gw::BoostMessageSender::send(const std::string& message) noexcept
{    
    std::future<std::size_t> result = socket.async_send_to(ba::buffer(message), endpoint, ba::use_future);

    return result.get() == message.size();
}
我像下面这样使用此类
int main()
{
    const string group_address = "235.127.1.1";
    constexpr uint16_t PORT_NUMBER = 8765;

    boost::asio::io_context io_context;

    BoostMessageSender message_sender(group_address, "eth1", PORT_NUMBER, io_context);

    std::thread t1([&io_context]()
        {
            io_context.run();
        });

    this_thread::sleep_for(1s);

    message_sender.send("Any bodey there?");

    cout << "send message: "; // --- this line is not run never :(((
    
    io_context.stop();
    t1.join();
    return 0;
}
我的问题是为什么send message永远不会在控制台中写入?
奇怪的是,我用tcpdump -i eth0 -nnSX port 8765检查我的网络,并在调用async_send_to之后可以看到发送到网络的多播消息,但是result.get()永远不会返回结果并卡在其上。
我哪里错了?
我在以下平台上测试这些代码
Visual Studio 2019 16.7.4
Windows 10 1909 latest update
Boost 1.73.0

Ubuntu 20.04.1 LTS
GCC 9.3.0
Boost 1.71.0

最佳答案

当没有挂起的作业要执行时,io_context::run返回。
您可以创建工作保护以确保即使没有启动异步任务也不会完成运行。使用make_work_guard函数:

boost::asio::io_context io_context;
auto workGuard = boost::asio::make_work_guard(io_context);

关于c++ - 使用use_future的Boost Asio async_send_to多播不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64061131/

相关文章:

c++ - 为什么这个未打开的 ifstream 在我尝试从中提取后仍然是 "good"?

c++ - 如何克服 double 不准确?

asynchronous - 使 TcpListener 异步处理连接的正确方法是什么?

c++ - 如何在C++程序中终止系统进程?

swift - 如何等待异步任务结束 - Swift 4

javascript - 异步并设置超时

c++ - 32位系统读取4GB文件的方法

c++ - Boost.Spirit气值序列 vector

c++ - Boost::Python 前向声明 boost::python::object 抛出 python TypeError

c++ - C++ 标准中错误使用 std::memory_order::relaxed 的示例 [n4713 中的 algorithms.parallel.exec/5]