boost::asio async_write也不能保证一次发完所有数据 一

简介: 你要是看过basic_stream_socket的文档,里面提到async_write_some不能保证将所有要发送的数据都发出去。并且提到如果想这样做,需要使用boost asio的async_write http://www.

你要是看过basic_stream_socket的文档,里面提到async_write_some不能保证将所有要发送的数据都发出去。并且提到如果想这样做,需要使用boost asio的async_write

http://www.boost.org/doc/libs/1_53_0/doc/html/boost_asio/reference/basic_stream_socket/async_write_some.html

 

[plain]  view plain copy print ?
 
  1. Remarks  
  2.   
  3. The write operation may not transmit all of the data to the peer. Consider using the async_write function if you need to ensure that all data is written before the asynchronous operation completes.  


但是这几天我就遇到一个问题,以前一直都是一次发送成功的。

 

我想发送54个字节的数据,可是每次都是只发9个字节。因此只好自己写了一个重试发送的递归函数。也很简单,通过bind,每次传递想要发送的字节数木和发送开始位置给异步回调函数。

代码参考如下:

 

[cpp]  view plain copy print ?
 
  1. void Sign::AfterWriteMessage(error_code const& ec, size_t bytes_transferred, size_t expected_size,  size_t offset) {  
  2.   if (ec) {  
  3.     BOOSTER_ERROR("AfterWriteMessage") << "write message failed, error code:" << ec.value()  
  4.                        << " category name:" << ec.category().name()  
  5.                        << " id_:" << id_  
  6.                        << " address:" << address    
  7.                        << " message:" << ec.message();  
  8.     Close();  
  9.     return;  
  10.   }  
  11.   
  12.   BOOSTER_DEBUG("AfterWriteMessage") << "thread id: " << this_thread::get_id() << " send_buffer: " << PrintBytesAsHexString(send_buffer, bytes_transferred) << " sent size:" << bytes_transferred;  
  13.   BOOSTER_DEBUG("AfterWriteMessage") << "thread id: " << this_thread::get_id() << " send_buffer: " << PrintBytesAsHexString(send_buffer, expected_size) << " expected size:" << expected_size;  
  14.     
  15.   size_t resend_size = expected_size - bytes_transferred;  
  16.   if (resend_size > 0) {  
  17.     size_t new_offset = offset + bytes_transferred;  
  18.     async_write(socket, buffer((void*)&send_buffer[new_offset], resend_size),  
  19.         strand_.wrap(bind(&Sign::AfterWriteMessage, shared_from_this(), _1, _2, resend_size, new_offset)));  
  20.     return;  
  21.   }  
  22.   
  23.   // do your business after send succeeds  
  24.     
  25. }  
  26.   
  27. void Sign::SendMessage(size_t size) {  
  28.   //  BOOSTER_DEBUG("SendMessage") << "thread id: " << this_thread::get_id() << " send_buffer: " << PrintBytesAsHexString(send_buffer, size) << " size:" << size;  
  29.   async_write(socket, buffer(send_buffer, size),  
  30.           strand_.wrap(bind(&Sign::AfterWriteMessage, shared_from_this(), _1, _2, size, 0)));  
  31. }  

 

但是为什么呢?难道真的是bug. 请看下一篇。

目录
相关文章
|
C语言 C++
boost库asio编译及配置
boost库asio编译及配置
596 0
conda常用操作和配置镜像源
conda常用操作和配置镜像源
29165 0
|
存储 NoSQL 算法
Redis之zset实现滑动窗口限流
Redis之zset实现滑动窗口限流
2203 0
Redis之zset实现滑动窗口限流
我的Qt作品(3)基于QTabWidget和AdvancedDocking实现的Ribbon风格主界面【开源】
我的Qt作品(3)基于QTabWidget和AdvancedDocking实现的Ribbon风格主界面【开源】
2153 0
我的Qt作品(3)基于QTabWidget和AdvancedDocking实现的Ribbon风格主界面【开源】
|
存储 安全 算法
【C++ 包装器类 std::atomic 】全面入门指南:深入理解并掌握C++ std::atomic 原子操作 的实用技巧与应用
【C++ 包装器类 std::atomic 】全面入门指南:深入理解并掌握C++ std::atomic 原子操作 的实用技巧与应用
1230 1
|
JSON Kubernetes 数据格式
访问kubernetes CRD的几种方式
访问kubernetes CRD的几种方式
145 1
|
消息中间件 前端开发 调度
C++20 协程——你还只是听过?觉得没时间了解,这里可以帮到你。五分钟 从没听过到使用的帮助手册
来源:协程是在C++20 标准中提出的一个新的工具。 它突破传统的程序在cpu中来回切换时需要更新和恢复PCB资源现场的耗时操作(多进程)或者COW(低级调度)操作时间。
402 0
|
编译器
嵌入式QT 树形浏览 - navListView
嵌入式QT 树形浏览 - navListView
|
编解码 算法
ENVI IDL:如何进行图像清晰度评价?
ENVI IDL:如何进行图像清晰度评价?
479 0
|
弹性计算 容灾 Linux
结合部属集策略实现更低的eRDMA时延
弹性RDMA(eRDMA)是阿里云ECS提供的RDMA加速功能。为了取得更低的延迟效果,我们可以结合上ECS的部属集策略,使eRDMA尽可能获取到更低的时延。
937 1