Запишите определенное количество данных в поток перед возвращением.
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.