阅读描述符(IOCTL,fcntl)
Descriptor for reading (ioctl, fcntl)
// 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;
}
pollfd
,原型在哪里定义?::poll
参考哪个文件的轮询?ioctl
,fcntl
适用于Unix和Windows系统?const null_buffers&
,传递对null_buffer的引用有什么用?
感谢
-
/usr/include/poll.h
poll.h
的那个!这是一个系统调用。- 不,此代码是特定于 unix 的。Windows确实有
WSAIoctl
,但没有与fcntl
完全相同的内容(您拼写错误(。 - 我不太了解Boost。您似乎已从
reactive_descriptor_service
类中提取了该代码。通常,read_some
方法读取数据,reactive_descriptor_service
看起来是接口的实现,它只是阻塞,直到可以读取,然后大概一些更高的调用者将读取和缓冲实际数据。因此,轮询调用可以通过通用接口进行优化和实现,而无需对所有数据进行双重缓冲。因此,内部类稍微重载了read_some
的含义,并且在此实现中,不使用缓冲区参数,因此传递了一个虚拟参数。
相关文章:
- 在 Linux 中使用 ioctl() 获取隐藏功能报告时,零字节消失
- ioctl错误在SPI传输函数中返回-1 EINVAL
- 正在等待在非阻塞文件描述符上长时间运行ioctl
- IOCTL 驱动程序系统缓冲区始终为空
- 使用 ioctl 以编程方式在C++中添加路由
- 视窗驱动程序IOCTL代码蓝屏/使计算机崩溃
- mutex或flock fcntl.h来锁定只写操作
- 如何使用标题fcntl.h和unistd.h读取和写入
- 为什么 fcntl() 标志值以八进制格式定义,以及此函数如何用于阻塞/非阻塞套接字?
- 哪个库'在明,我链接fcntl.h和unistd.h
- 我应该在标头"fcntl.h"中修改此错误吗?
- 为什么linux中有多个fcntl.h
- 在哪里可以找到 IOCTL 常量值
- 具有 FIONREAD 返回值的 ioctl
- 阅读描述符(IOCTL,fcntl)
- fcntl() 中的第三个参数是什么
- 发送IOCTL到Windows设备驱动程序- CreateFile失败
- 不适合设备的ioctl
- 可以检查ioctl的权限
- 工作线程中的同步与异步ioctl