Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.07.21;
Скачать: CL | DM;

Вниз

TThread   Найти похожие ветки 

 
Flint ©   (2003-07-07 12:51) [0]

Здравствуйте! у меня такая ситуация:
1) есть поток который вычитывает данные из СОМ-порта
2) есть класс-оболочка для управления этим потоком
3) по приходу данных поток отдает оболочке данные через обработчик события OnNewData
4) далее класс-оболочка отдает данные в приложение тоже через обработчик события
Вопрос: как сделать этот процесс асинхронным, чтобы класс-оболочка не ждал когда в приложении обработаются данные (это может быть достаточно длительное время), а отпускал обработчик ?

P.S. У меня пока реализованно через PostMessage в самом приложении, но хотелось бы реализовать это в классе-оболочке.


 
Digitman ©   (2003-07-07 13:45) [1]

В классе-оболочке реализуй
- очередь данных на обработку, например, на базе TThreadList;
- некий метод GetQueueEntry(), который будет выбирать из головы очереди данные; в хвост очереди данные будут поступать в событии OnNewData(), которое обрабатывает класс-оболочка, вызывая там некий метод PutQueueEntry().

Кодовый поток, обрабатывающий событие класса-оболочки, будет тем самым получать извещения о непустой очереди и, вызвав метод GetQueueEntry(), получать очер.элемент для асинхр.обработки.

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



Страницы: 1 вся ветка

Текущий архив: 2003.07.21;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.016 c
14-67989
Alesander
2003-07-02 17:46
2003.07.21
Подбор паролей в Windows 98


14-68064
SergP
2003-07-06 00:11
2003.07.21
Посоветуйте алгоритм для криптования строки


4-68107
Mr. API
2003-05-15 20:15
2003.07.21
В WinXP создается прозрачное окно.


7-68085
SDW_syscoder
2003-05-12 01:19
2003.07.21
Assembler in Delphi


1-67768
Луарвик
2003-07-08 19:02
2003.07.21
Смена картинки на форме...