0
 // Wait until data can be read without blocking.
  size_t read_some(implementation_type& impl,
      const null_buffers&, asio::error_code& ec)
  {
    // Wait for descriptor to become ready.
    descriptor_ops::poll_read(impl.descriptor_, ec);

    return 0;
  }

在descriptor_ops里面

     int poll_read(int d, asio::error_code& ec)
{
  if (d == -1)
  {
    ec = asio::error::bad_descriptor;
    return -1;
  }

  pollfd fds;
  fds.fd = d;
  fds.events = POLLIN;
  fds.revents = 0;
  errno = 0;
  int result = error_wrapper(::poll(&fds, 1, -1), ec);
  if (result >= 0)
    ec = asio::error_code();
  return result;
}
  1. pollfd,原型在哪里定义?

  2. ::poll指的是哪个文件的民意调查?

  3. ioctlfcntl适用于unix 和window 系统?

  4. const null_buffers&,传递对 null_buffer 的引用有什么用?

谢谢

4

1 回答 1

1
  1. /usr/include/poll.h
  2. 里面的那个poll.h!这是一个系统调用。
  3. 不,此代码是特定于 unix 的。Windows 确实有,但没有与(您拼写错误WSAIoctl的)完全相同的内容。fcntl
  4. 我不太了解Boost。您似乎已从reactive_descriptor_service课程中提取了该代码。通常,该read_some方法读入数据,reactive_descriptor_service看起来是接口的实现,它只是阻塞直到可以读取,然后可能一些更高的调用者将读取并缓冲实际数据。因此,轮询调用可以通过通用接口进行优化和实现,而无需双缓冲所有数据。因此,内部类read_some稍微重载了含义,并且在此实现中,未使用 buffers 参数,因此传递了一个虚拟参数。
于 2013-08-29T17:08:59.713 回答