Карта сайта Kansoftware
НОВОСТИУСЛУГИРЕШЕНИЯКОНТАКТЫ
Разработка программного обеспечения

windows::basic_random_access_handle::async_write_some_at

Boost , Boost.Asio , windows::basic_random_access_handle

Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

PrevUpHomeNext

Начните асинхронную запись при указанном смещении.

template<
    typename ConstBufferSequence,
    typename WriteHandler>
void-or-deduced async_write_some_at(
    uint64_t offset,
    const ConstBufferSequence & buffers,
    WriteHandler handler);

Эта функция используется для асинхронной записи данных в ручку случайного доступа. Звонок функции всегда возвращается немедленно.

Parameters

offset

Смещение, при котором будут записаны данные.

buffers

Один или несколько буферов данных, которые должны быть записаны на ручку. Хотя объект буферов может быть скопирован по мере необходимости, право собственности на базовые блоки памяти сохраняется абонентом, который должен гарантировать, что они остаются действительными до тех пор, пока обработчик не будет вызван.

handler

Обработчик должен быть вызван, когда операция записи завершится. Копии будут сделаны из обработчика по мере необходимости. Функциональная подпись обработчика должна быть:

void handler(
  const boost::system::error_code& error, // Result of operation.
  std::size_t bytes_transferred           // Number of bytes written.
);

Независимо от того, выполняется ли асинхронная операция немедленно или нет, обработчик не будет вызываться из этой функции. Запрос обработчика будет выполнен способом, эквивалентным использованию<boost::asio::io_service::post()>.

Remarks

Операция записи может не передавать все данные одноранговому устройству. Подумайте об использовании функции<async_write_at>, если вам нужно убедиться, что все данные записаны до завершения асинхронной операции.

Example

Для записи одного буфера данных используйте функцию<buffer>следующим образом:

handle.async_write_some_at(42, boost::asio::buffer(data, size), handler);

Смотреть<buffer>документация для информации о написании нескольких буферов за один ход, и как использовать его с массивами, бустер::array или std::vector.


PrevUpHomeNext

Статья windows::basic_random_access_handle::async_write_some_at раздела Boost.Asio windows::basic_random_access_handle может быть полезна для разработчиков на c++ и boost.




Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.



:: Главная :: windows::basic_random_access_handle ::


реклама


©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007
Top.Mail.Ru

Время компиляции файла: 2024-08-30 11:47:00
2025-05-19 19:52:19/0.027850151062012/1