boost::asio - peeking into a socket buffer(boost::asio - 窥视套接字缓冲区)
问题描述
我使用 boost::asio::read (或者可能是等效的 async_read) 从套接字读取一些数据.
I use boost::asio::read (or may be the equivalent async_read) to read some data from a socket.
是否可以将读取的字节保留在底层套接字中,以便下次在套接字上调用 read 时再次收到该数据?
Is it possible that I leave the bytes read in the underlying socket so that next time I call read on the socket I receive again that data ?
推荐答案
就像 Simon 说的,你不能用 boost::asio::read() (或 boost::asio::async_read()).但是,对于 read() 您可以在套接字上调用 native_handle() 以获取套接字描述符,然后将 ::recvmsg() 与MSG_PEEK 标志.同样,您可以使用 null_buffers() 作为接收缓冲区调用 async_read(),然后使用 native_handle()/::recvmsg() 技巧来查看数据.查看 本节关于如何使用 null_buffers() 的 boost 文档.
Like Simon said, you can't do it with boost::asio::read() (or boost::asio::async_read()). However, for read() you could call native_handle() on the socket to get the socket descriptor and then use ::recvmsg() with the MSG_PEEK flag. Similarly, you could call async_read() with null_buffers() as the receive buffer and then use the native_handle()/::recvmsg() trick to peek the data. Check out this section of the boost documentation for how to use null_buffers().
这篇关于boost::asio - 窥视套接字缓冲区的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:boost::asio - 窥视套接字缓冲区
基础教程推荐
- c++ STL设置差异 2022-01-01
- 将不可复制的闭包对象传递给 std::function 参数 2021-01-01
- 如何更改 SysDateTimePick32 或 CDateTimeCtrl 的背景颜色? 2022-01-01
- 如何在 C++ 中正确使用命名空间? 2022-01-01
- 与 CAS 的原子交换(使用 gcc 同步内置函数) 2022-01-01
- C++:获取传递给函数的多维数组的行大小 2021-01-01
- 随机插入/删除的综合向量与链表基准 2022-01-01
- 如何部分禁用 cmake C/C++ 自定义编译器检查 2021-01-01
- 提升 ASIO 流缓冲 2021-01-01
- 为什么我们不能使用“虚拟继承"?在 COM 中? 2022-01-01
