Главная страница
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.017 c
1-67808
Wetnose
2003-07-09 08:24
2003.07.21
BPL dependences


14-67978
Nevermind
2003-07-07 10:59
2003.07.21
Кнопка в Coolbar е IE


1-67856
Igor_P
2003-07-07 22:50
2003.07.21
MessageDlg


14-67960
Карелин Артем
2003-07-03 15:10
2003.07.21
Программирование под Win CE на дельфи.


1-67797
guest0
2003-07-04 08:03
2003.07.21
Горячие клавиши