Запишите определенное количество данных в поток перед возвращением.
template<
    typename SyncWriteStream,
    typename ConstBufferSequence,
    typename CompletionCondition>
std::size_t write(
    SyncWriteStream & s,
    const ConstBufferSequence & buffers,
    CompletionCondition completion_condition);
Эта функция используется для записи определенного количества байтов данных в поток. Звонок будет блокироваться до тех пор, пока не будет выполнено одно из следующих условий:
- Все данные в предоставленных буферах были записаны. То есть переданные байты равны сумме буферных размеров.
 
- Объект функции завершения_условия возвращает 0.
 
 
Эта операция реализована с точки зрения нулевого или большего количества вызовов функции write_some потока.
- s
 
Поток, к которому должны быть записаны данные. Этот тип должен поддерживать концепцию SyncWriteStream.
 
- buffers
 
Один или несколько буферов, содержащих данные, подлежащие записи. Сумма размеров буфера указывает на максимальное количество байтов для записи в поток.
 
- completion_condition
 
- 
Объект функции должен быть вызван, чтобы определить, завершена ли операция записи. Подпись объекта функции должна быть:
std::size_t completion_condition(
  
  const boost::system::error_code& error,
  
  std::size_t bytes_transferred
);
Возвратное значение 0 означает, что операция записи завершена. Ненулевое значение возврата указывает на максимальное количество байтов, которые будут записаны на следующем вызове функции write_some потока.
 
 
Количество переданных байтов.
- boost::system::system_error
 
Выброшен на провал.
 
 
Для записи одного буфера данных используйте функцию<buffer>следующим образом:
boost::asio::write(s, boost::asio::buffer(data, size),
    boost::asio::transfer_at_least(32));
См. документацию<buffer>для информации о написании нескольких буферов за один раз, а также о том, как использовать его с массивами, нарастить::array или std::vector.