将数据读入循环缓冲区

Rob*_*ner 6 c++ boost network-programming circular-buffer boost-asio

是否有可能使用boost::circular_bufferboost::asio

具体来说,我想读取固定数量的字节boost::asio::async_write并将它们直接存储在循环缓冲区中而不进行复制。

一些示例代码会非常好!

rus*_*tyx 2

截至目前(Boost 1.66),无法将数据boost::circular_buffer入,因为它没有公开任何在底层缓冲区中保留空间的方法,这是创建mutable_buffer所需的调用的要求asio::read

但可以这样boost::circular_buffer

  boost::circular_buffer<char> cir_buf;

  FillBuffer(cir_buf);

  // Construct a buffer sequence with either 1 or 2 data chunks
  std::vector<boost::asio::const_buffer> buffer_sequence;

  auto arr1 = cir_buf.array_one();
  buffer_sequence.push_back(boost::asio::buffer(arr1.first, arr1.second));

  auto arr2 = cir_buf.array_two();
  if (arr2.second != 0) {
    buffer_sequence.push_back(boost::asio::buffer(arr2.first, arr2.second));
  }

  boost::asio::write(socket_, buffer_sequence);
Run Code Online (Sandbox Code Playgroud)