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 - 窥视套接字缓冲区
- Stroustrup 的 Simple_window.h 2022-01-01
- 从python回调到c++的选项 2022-11-16
- 近似搜索的工作原理 2021-01-01
- 与 int by int 相比,为什么执行 float by float 矩阵乘法更快? 2021-01-01
- 静态初始化顺序失败 2022-01-01
- C++ 协变模板 2021-01-01
- 一起使用 MPI 和 OpenCV 时出现分段错误 2022-01-01
- 使用/clr 时出现 LNK2022 错误 2022-01-01
- 如何对自定义类的向量使用std::find()? 2022-11-07
- STL 中有 dereference_iterator 吗? 2022-01-01
