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