На главную Наши проекты:
Журнал   ·   Discuz!ML   ·   Wiki   ·   DRKB   ·   Помощь проекту
ПРАВИЛА FAQ Помощь Участники Календарь Избранное RSS
msm.ru
Обратите внимание:
1. Прежде чем начать новую тему или отправить сообщение, убедитесь, что вы не нарушаете правил форума!
2. Обязательно воспользуйтесь поиском. Возможно, Ваш вопрос уже обсуждали. Полезные ссылки приведены ниже.
3. Темы с просьбой выполнить какую-либо работу за автора в этом разделе не обсуждаются.
4. Используйте теги [ code=cpp ] ...текст программы... [ /code ] для выделения текста программы подсветкой.
5. Помните, здесь телепатов нет. Старайтесь формулировать свой вопрос максимально грамотно и чётко: Как правильно задавать вопросы
6. Запрещено отвечать в темы месячной и более давности без веских на то причин.

Полезные ссылки:
user posted image FAQ Сайта (C++) user posted image FAQ Форума user posted image Наши Исходники user posted image Поиск по Разделу user posted image MSDN Library Online (Windows Driver Kit) user posted image Google

Ваше мнение о модераторах: user posted image B.V.
Модераторы: B.V.
  
> Вопрос по именованным каналам
    Здравствуйте!

    Возник вопрос касательно работы именованных каналов в локальной сети с асинхронным вводом-выводом.

    Допустим мы сделали запрос на чтение/запись 128 Кб данных. Может ли быть такое, что запрос завершится удачно, но данные будут прочитаны/записаны не все? Например GetOverlappedResult вернет TRUE, но в lpNumberOfBytesTransferred будет возвращено только 64 Кб. То есть потребуется дочитать/дописать данные.
      Да, такое возможно. При работе с асинхронным вводом-выводом, когда используются буферы ограниченного размера, есть вероятность, что запрос завершится удачно, но количество переданных/принятых байтов будет меньше, чем запрашиваемое. Это может произойти, например, если буфер, в котором хранятся данные для передачи, заполнен не полностью, либо если приемный буфер был заполнен ранее принятыми данными.

      Чтобы обработать такую ситуацию, в приложении можно использовать циклы для повторной передачи/приема данных до тех пор, пока не будет получено запрошенное количество данных, либо не будет достигнуто максимальное количество попыток. Также можно использовать буферы большего размера, чтобы уменьшить вероятность неполной передачи/приема данных.
      0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)
      0 пользователей:


      Рейтинг@Mail.ru
      [ Script execution time: 0,0169 ]   [ 16 queries used ]   [ Generated: 29.03.24, 00:23 GMT ]