- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
它写在 documentation 中:
This function is used to asynchronously read data from the stream socket. The function call always returns immediately.
我知道它是异步的,所以它立即返回。但是 async_read_some()
与自由函数 read() 有何不同?当我尝试 std::cout
用于 async_read_some()
的缓冲区时,该函数似乎读取了很多次,直到流中没有数据。
这是否意味着 async_read_some()
不断请求直到它收到每个数据,例如,在 HTTP GET 请求中?服务器会一次写入一点点并发送一点点给客户端(async_read_some()
读取一点点整个数据),或者一次将所有数据转储给客户端?
最佳答案
不,async_read_some()
不连续请求。
ip::tcp::socket::async_read_some()
函数将进行系统调用以开始读取。
之后,下次您在传递给 ip::tcp 的构造函数的
,io_service
上调用 io_service::run()
时: :socketio_service
将检查 async_read_some()
是否读取了任何数据。
如果数据已被读取,那么它将调用您传递给 async_read_some()
的 ReadHandler
回调。
如果尚未读取数据,它将返回并在您下次调用 io_service::run()
时再次检查是否完成。
关于c++ - boost::asio::ip::tcp::socket 中的 async_read_some() 是如何工作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7785761/
在 Boost::ASIO 中有没有办法知道 async_read_some 是否不会在特定时间段内返回以在不关闭套接字的情况下调用函数?如果没有更多数据要传输到缓冲区,通常 async_read_s
我的程序总是使用依赖于平台的同步接收,它会阻塞执行直到超时或接收事件,例如: recv(buf, size, timeout); 现在我想用 boost 替换这段代码,使其跨平台。我找到了解决方案,但
我正在使用非 boost asio 编写一个简单的异步服务器。我遇到了一个巨大的模板错误,坦率地说,我什至无法想象这意味着什么。 作为引用,我的代码看起来很像 http://think-async.c
这是我的服务器代码: socket_.async_read_some(boost::asio::buffer(data_read.data(), Message::header_length),
所以我在练习 boost 库时遇到了一些问题。我的应用程序使用 asio::serial_port,我决定添加一些日志功能。问题来了。 当我为 asio::io_service 创建线程时 boost
我在实现一个简单的 TCP 服务器时遇到了困难。以下代码摘自boost::asio examples ,准确地说是“Http 服务器 1”。 void connection::start() {
如何将 sock.async_read_some 的 read_handler 调用同步到特定频率,同时读取 812 字节的流(以 125 Hz 的频率流式传输)。 我有一个与从机器人读取流相关的问题
我尝试使用以下代码读取套接字中的可用字节数(在服务器端),变量 packet_bytes 没有做任何事情。我期望将数据包使用的字节数读入 packet_bytes 但这似乎不起作用。 std::siz
我正在使用 TCP echo 示例(1.62 是目前在主要 Ubuntu 软件包中提供的版本)。 https://www.boost.org/doc/libs/1_62_0/doc/html/boos
我正在为基于 HTTP Server 3 的 Mac OS X 开发一个 Boost asio 网络程序例子。它使用 async_read_some 从 TCP 套接字异步读取数据。 问题是我的处理程
我有一个使用 boost::asio 进行读/写操作的 C++ 服务器 - 写出消息工作正常 - 但由于某种原因我无法读取工作 我从客户端发送给它的消息是 15 16 位无符号短裤 - 我的测试消息是
假设在 boost::asio 中的套接字上启用了 async_read_some 服务,如果在同一套接字上调用阻塞读取会发生什么情况? 一段伪代码如下: using boost::asio::loc
我使用带有超时的 async_read_some 来使用这段代码 readdata=0; port_->async_read_some(boost::asio::buf
我试图在我的 C++ 程序中通过 http 接收一个包。我为此目的使用 Boost.Asio。 在我的 handleAccept 方法中,我有这个代码来读取包: // m_buffer is
我正在使用以下方法: boost::asio::streambuf io_bufstream; boost::asio::async_read_until(socket_, io_bufstream,
我的代码适用于 read_some,但不适用于 async_read_some。我正在读取的数据长度为 5 个字符,而 MAX_RESPONSE_SIZE 256。打开端口后,我从 main 中调用了
假设我有一个 Boos.Asio TCP 客户端,它可以发送一个字符串,如下所示: client.sendStr("1111"); 我还有一个异步的 Boost.Asio TCP 服务器,它将处理传入
上下文:我正致力于在与 Boost ASIO 集成的 RDMA 包装器库之上实现一个简单的流适配器。 我遇到的问题是,客户端代码调用的 boost::asio::async_read 聚合器挂起,即使
我有一个服务器使用来自 boost 的异步套接字和“接受”函数,如下所示(“用户”几乎等同于 this 示例中的“ session ”): accept() { this->_acce
为了理解 boost asio 库,我实现了一个异步回显服务器。我要求 tcp::socket 为少量数据执行 async_read_some,即 9 个字节(选择用于测试的小数字),即 socket
我是一名优秀的程序员,十分优秀!