阅读描述符(IOCTL,fcntl)

Descriptor for reading (ioctl, fcntl)

本文关键字:fcntl IOCTL 描述      更新时间:2023-10-16
 // 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和Windows系统?

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

感谢

  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的含义,并且在此实现中,不使用缓冲区参数,因此传递了一个虚拟参数。