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

Вниз

В чем проблема обращения к TPFibDataBase по указателю в Dll?   Найти похожие ветки 

 
Aleksandr.   (2005-08-08 15:40) [0]

Программа использует embedded FireBird, поэтому TPFibDataBase в ней для одновременных коннектов может быть только одна. Функционал, использующий соединения к базе, разделен на две части - непосредственно код программы и dll. В dll при вызове функции инициализации ее внутреннего объекта передается Pointer PFIBDataBase, размещенной на DataModule программы, а в констракторе объекта, соответственно, приводится к его внутреннему свойству обратно ( FDB:=TPFIBDataBase(DBPointer); ).
Кроме того, на DataModule программы есть две TPFIBTransaction, у которых FIBDataBase установлена в DefaultDataBase, а у FIBDataBase эти транзакции установлены в DefaultTransaction и DefaultUpdateTransaction. У внутреннего объекта dll есть свои две аналогичные транзакции (в дефолты PFIBDataBase они не устанавливаются, просто назначаются соответствующим свойствам объектам TPFIBQuery и TPFIBDataSet). И вот наблюдается непонятная картина: при первом вызове функций библиотеки все работает отлично, а при втором начинают вылетать AccessViolation при попытке вызовов типа FDB.GetTableNames, хотя трассировка показывает наличие нормальных объектов (не уничтоженных, судя по тому, что их свойства не Inaccessible value). В чем причина такого поведения переданного по указателю компонента? Если FDB создается своя внутри библиотеки, то проблем не возникает (это для тех, кто может посчитать, что ошибка в коде обращения к FDB).


 
Виталий Панасенко   (2005-08-08 17:47) [1]

Для вызова из DLL нужно использовать УДАЛЕННЫЙ доступ..Точнее, формат подключения..Не DataBaseName=C:\db.FDB,а DataBaseName=LOCALHOST:\c:db.FDB...



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

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

Наверх




Память: 0.47 MB
Время: 0.031 c
14-1124270492
vtsoy
2005-08-17 13:21
2005.09.18
Что такое API?


6-1117191058
Dysan
2005-05-27 14:50
2005.09.18
какова максимальная нагрузка у idTCPServer


8-1115452586
Киря
2005-05-07 11:56
2005.09.18
Как отследить событие?


14-1125068503
P.N.P.
2005-08-26 19:01
2005.09.18
Фрилансер


14-1124613753
Е-клмн
2005-08-21 12:42
2005.09.18
Какой правитель лучше: тот, которого боятся или тот, над которым