asio之fd_set_adapter

简介

fd_set_adapter是对fd_set的封装

fd_set_adapter

是不同平台fd_set的别名

#if defined(BOOST_ASIO_WINDOWS) || defined(__CYGWIN__)
typedef win_fd_set_adapter fd_set_adapter;
#else
typedef posix_fd_set_adapter fd_set_adapter;
#endif

posix_fd_set_adapter

linux平台的fd_set适配器

posix_fd_set_adapter
- fd_set fd_set_
- socket_type max_descriptor_
+void reset()
+bool set(socket_type descriptor)
+void set(reactor_op_queue& operations, op_queue& ops)
+bool is_set(socket_type descriptor)
+operator fd_set*()
+socket_type max_descriptor()
+void perform(reactor_op_queue& operations, op_queue& ops)

set函数遍历operations中描述符添加到fd_set中,如果失败,则取消对应的操作

  void set(reactor_op_queue<socket_type>& operations, op_queue<operation>& ops)
  {
    reactor_op_queue<socket_type>::iterator i = operations.begin();
    while (i != operations.end())
    {
      reactor_op_queue<socket_type>::iterator op_iter = i++;
      if (!set(op_iter->first))
      {
        boost::system::error_code ec(error::fd_set_failure);
        operations.cancel_operations(op_iter, ops, ec);
      }
    }
  }

 bool cancel_operations(iterator i, op_queue<operation>& ops,
      const boost::system::error_code& ec =
        boost::asio::error::operation_aborted)
  {
    if (i != operations_.end())
    {
      while (reactor_op* op = i->second.front())
      {
        op->ec_ = ec;
        i->second.pop();
        ops.push(op);
      }
      operations_.erase(i);
      return true;
    }

    return false;
  }

perform遍历operations中描述符检查是否在fd_set中,如果在,则执行操作

void perform(reactor_op_queue<socket_type>& operations,
      op_queue<operation>& ops) const
  {
    reactor_op_queue<socket_type>::iterator i = operations.begin();
    while (i != operations.end())
    {
      reactor_op_queue<socket_type>::iterator op_iter = i++;
      if (is_set(op_iter->first))
        operations.perform_operations(op_iter, ops);
    }
  }

bool perform_operations(iterator i, op_queue<operation>& ops)
  {
    if (i != operations_.end())
    {
      while (reactor_op* op = i->second.front())
      {
        if (op->perform())
        {
          i->second.pop();
          ops.push(op);
        }
        else
        {
          return true;
        }
      }
      operations_.erase(i);
    }
    return false;
  }

win_fd_set_adapter

windows平台fd_set的适配器

win_fd_set_adapter
- win_fd_set* fd_set_
- u_int capacity_
- socket_type max_descriptor_
+void reset()
+bool set(socket_type descriptor)
+void set(reactor_op_queue& operations, op_queue&)
+bool is_set(socket_type descriptor)
+operator fd_set*()
+socket_type max_descriptor()
+void perform(reactor_op_queue& operations, op_queue& ops)
  • 8
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
`boost::asio::signal_set` 是 Boost.Asio 库中的一个类,用于异步处理操作系统信号。它允许您注册一个或多个信号,并在信号触发时异步执行回调函数。这对于在异步 I/O 应用程序中处理信号非常有用,例如在服务器应用程序中优雅地关闭或重启。 以下是 `boost::asio::signal_set` 的一些常用方法: - `signal_set(boost::asio::io_context& io_context, int signal_number)`:构造函数,创建一个 signal_set 对象并关联一个 io_context 和一个信号编号。 - `void async_wait(std::function<void(const boost::system::error_code& error, int signal_number)> handler)`:异步等待信号。当信号触发时,将调用给定的处理程序。 - `void cancel()`:取消任何等待的操作。 示例代码如下: ```c++ #include <iostream> #include <boost/asio.hpp> void signal_handler(const boost::system::error_code& error, int signal_number) { if (!error) { std::cout << "Received signal " << signal_number << std::endl; } } int main() { boost::asio::io_context io_context; boost::asio::signal_set signals(io_context, SIGINT, SIGTERM); signals.async_wait(signal_handler); io_context.run(); return 0; } ``` 在上面的示例中,我们创建了一个 `boost::asio::signal_set` 对象并注册了 `SIGINT` 和 `SIGTERM` 信号。然后,我们调用 `async_wait` 方法来异步等待信号,并在信号触发时调用 `signal_handler` 回调函数。最后,我们通过调用 `io_context.run()` 方法来运行异步操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kgduu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值