Модераторы: Snowy, bartram, MetalFan, bems, Poseidon, Riply
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Непрерывное чтение последовательного порта 
:(
    Опции темы
cemick
Дата 28.12.2013, 10:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 416
Регистрация: 6.7.2006
Где: Санкт-Петербург

Репутация: нет
Всего: 6



Добрый день.  

Читаю из COM порта в асинхронном режиме с помощью Winapi. Все хорошо, кроме одного "Но"

Немного псевдо кода:

While not Terminated do   
  WaitCommEvent
  WaitForSingleObject
  GetOverlappedResult
  ReadFile

Проблема заключается в следующем, если данные в COM порт поступят после ReadFile, НО до WaitCommEvent, я не узнаю об этом, и в WaitForSingleObject буду ждать пока еще раз не будет в COM порт выполнена посылка данных. Данные не потеряются, но получу временной лаг. 
В этом и вопрос, как сделать так, что бы WaitCommEvent-WaitForSingleObject  сразу сообщили о том, что данные уже есть и неждали нового поступления данных.

Это сообщение отредактировал(а) cemick - 28.12.2013, 10:19
PM MAIL WWW   Вверх
Robus
Дата 30.3.2014, 04:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Entire



Профиль
Группа: Участник
Сообщений: 32
Регистрация: 15.12.2005

Репутация: нет
Всего: 1



Цитата(cemick @  28.12.2013,  10:18 Найти цитируемый пост)
В этом и вопрос, как сделать так, что бы WaitCommEvent-WaitForSingleObject  сразу сообщили о том, что данные уже есть и неждали нового поступления данных.

В виндовсе, по крайней мере современном, давно ушли от прерываний. Поэтому нужно создать отдельный поток в котором, в цикле, крутить чтение с порта, считывать их и класть в какой-нибудь буфер. В основном цикле проверять наличие данных в буфере в нужный и удобный для вас момент и действовать по логике работы. Если вам непосредственно нужно прерывание по приходу данных, технология та же самая, но после чтения данных вызывать процедуру из потока.
Я постоянно пишу системное ПО и использую процедуру в качестве прерывания, очень удобно и надёжно. Для полного удобства я себе сделал UNIT, который параллельно работает с 256 портами, в принципе написание ПО сводится к набору простейших процедуру типа "ComOpen, ComClose, ComSend/Read", а уже UNIT сам открывает потоки, получает данные и вызывает процедуры прерывания.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: WinAPI и системное программирование"
Snowybartram
MetalFanbems
PoseidonRrader
Riply

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Литературу по Delphi обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • 99% ответов по WinAPI можно найти в MSDN Library, оставшиеся 1% здесь

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, bartram, MetalFan, bems, Poseidon, Rrader, Riply.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: WinAPI и системное программирование | Следующая тема »


 




[ Время генерации скрипта: 0.0728 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.