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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Пропуск dde-данных, Программа не успевает за dde-потоком 
:(
    Опции темы
Flap
Дата 21.4.2008, 08:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Помогите с проблеммой, точнее их две:

1. Моя программа в режиме Advise слушает некий сервер с которого падают данные. Эти данные надо принять и поместить в таблицу в определенную строку. Проблемма в том, что, когда эти данные валят часто, то случаются пропуски и в таблице появляются пробелы. Как этого можно избежать?

2. Далее, TDdeClientItem очень много, все они создаются динамически и хранятся в TList. И у всех OnChange - один и тот же. Собственно в этой OnChange и происходит запись в таблицу. Можно как-то сделать так, чтобы TDdeClientItem был один и просто ловил все, что падает на TDdeClientConv?

OnChange уже оптимизировал как мог. Работу с таблицей я ускорить не могу уже (там всего один Locate, далее Edit и Post).

Поможет ли в этом случае многопоточность и как, в этом случае, синхронизивать запись из всех потоков в одну таблицу?

В качестве таблицы использую TMemTableEh.

Буду очень признателен, за хоть какие-нибудь советы.
Спасибо.
PM MAIL   Вверх
bems
Дата 22.4.2008, 12:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 3400
Регистрация: 5.1.2006

Репутация: 21
Всего: 88



если "лавины" данных чередуются с "затишьями", то можно обойтись и без потоков. В OnChange пиши данные в промежуточное хранилище (экономия времени на Locate), а при простое приложения пиши в базу. 


--------------------
Обижено школьников: 8
PM MAIL   Вверх
Flap
Дата 22.4.2008, 14:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Так в том-то и дело, что неизвестно, когда будет затишье. Начну кэш разгребать, а они опять посыпятся. Буду думать дальше. Хотя, как вариант, можно вообще от таблицы отказаться, а сделать что-то быстрое.
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.

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


 




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


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

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