Форум: "Основная";
Текущий архив: 2003.07.21;
Скачать: [xml.tar.bz2];
Вниз
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;
Скачать: [xml.tar.bz2];
Память: 0.44 MB
Время: 0.008 c