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

Вниз

Доступ к переменной главного потока?   Найти похожие ветки 

 
d@vinchi ©   (2009-09-22 10:30) [0]

Вопрос для большинсва детский, но я впервые сталкиваюсь так плотно с потоками и данной ситуацией. В общем приложение является службой. В обработчике создания службы создается TServerSocket и средствами DAO xxx.mdf база данных для ведения логов. В обработчике TServerSocket.OnClientRead происходит анализ полученных данных и при необходимости запись в БД. Если в обработчике TServerSocket.OnClientRead к БД обращаться через глобальные переменные, то возникает ошибка "неверный адрес...". Если БД создавать не в TService.OnCreate, а в обработчике TServerSocket.OnClientRead, то обращение и запись данных проходит етественно нормально, НО при интенсивном потоке входящих данных все это происходит долго, т.к. каждый раз происходит создание объекта DAO, открытие БД, открытие RecordSet.
Предпологаю что проблема в доступе к переменной главного потока из дочернего потока - какое решение применяется в этой ситуации?


 
Сергей М. ©   (2009-09-22 11:38) [1]


> проблема в доступе к переменной главного потока из дочернего
> потока


Обращения именно из дочернего потока из объяснения не очевидны


 
Сергей М. ©   (2009-09-22 11:54) [2]


> В обработчике создания службы создается TServerSocket


Активируется там же ?
Значит обработчики всех событий TServerSocket вызываются в осн.потоке, потому что обработчик TService.OnCreate/OnDestroy вызвается именно в основном. Все прочие события TService возбуждаются в доп.потоке.


 
d@vinchi ©   (2009-09-22 12:07) [3]

Активируется в OnStart, из него же вызывается метод записи лога в котором возникает ошибка... Т.е. если перенести активацию TServerSocket  в OnCreate службы событие OnClientRead будет возникать в основном потоке службы - я правильно понял?


 
Сергей М. ©   (2009-09-22 12:21) [4]

Правильно.


 
d@vinchi ©   (2009-09-22 13:41) [5]

Спасибо! все получилось после небольших переделок...


 
Сергей М. ©   (2009-09-22 13:51) [6]


> все получилось


И теперь у тебя вся ключевая функциональность сервиса работает в осн.потоке ?
Ну и какой тогда смысл в использовании именно сервиса ?



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

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

Наверх




Память: 0.48 MB
Время: 0.013 c
15-1252269007
Юрий
2009-09-07 00:30
2009.11.08
С днем рождения ! 7 сентября 2009 понедельник


2-1253681952
Ksandr
2009-09-23 08:59
2009.11.08
Access без ODBC... как...???


13-1124174625
inspirion
2005-08-16 10:43
2009.11.08
IIS 5.1 и ASP.NET


3-1229329218
namco
2008-12-15 11:20
2009.11.08
sql server + delphi как сделать


2-1249581150
Maridena
2009-08-06 21:52
2009.11.08
Редактирование данных в DBGrid в случае заполнения DBGrid изQuerу