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

Вниз

DLL. Ошибка при использовании типа string в ее функциях   Найти похожие ветки 

 
Старик   (2006-03-22 07:31) [0]

Привет.
Напоролся на ошибку при выгрузке DLL из памяти (FreeLibrary), если в них есть функции, возвращающие результатом string.

В моих DLL была такая функция для идентификации (я использую динамическое подключение), которая возвращала string.
Эта ошибка исчезла, стоило мне только заменить тип функции со string на PChar. Т.е. саму проблему я решил.
Если кто-нибудь знает, в чем здесь суть проблемы, поделитесь своими соображениями.


 
MBo ©   (2006-03-22 08:03) [1]

При создании проекта-DLL вначале идет комментарий. Читал?


 
Старик   (2006-03-22 08:37) [2]

Да, читал. Насколько я понял, там говорится о том, что для использования string нужно подключить модуль ShareMem, иначе юзать не string, а PChar или ShortString. Но меня интересует сама причина этого явления.


 
MBo ©   (2006-03-22 08:48) [3]

Причина в том, что при работе с длинными строками и динамическими массивами  в основной программе и DLL должен использоваться единый менеджер памяти. Вот подключение Sharemem это как раз и обеспечивает (правда, ценой таскания с собой borlndmm.dll)


 
Сергей М. ©   (2006-03-22 08:52) [4]


> меня интересует сама причина этого явления


Причина проста - при формировании результата ф-ции память под значение типа String выделяется одним экземпляром менеджера памяти, а освободить эту память после получения результата пытается другой экз-р менеджера памяти. А у каждого экз-ра менеджера памяти свои внутренние списки, в которых менеджер ведет учет блоков памяти, формируемых вызовами GetMem/ReallocMem/FreeMem. Сабж, кстати, касается не только String, но и любых типов данных, явно или неявно подразумевающих динамическое перераспределение памяти при передаче в DLL параметров и получении результатов.

Решение при этом очевидно - дать компилятору указание об использовании вызывающим и вызываемым кодом единого экз-ра менеджера. Это достигается либо использованием ShareMem (в нем реализован тот самый независимый менеджер) либо сборкой взаимодействующих проектов с установленной опцией линкера Build With Run-Time Packages (в этом случае будет использован единый менеджер в составе RTLXX.BPL)


 
Старик   (2006-03-22 09:03) [5]

Сергей М., MBo
Спасибо, что доступно растолковали :)


 
Amoeba ©   (2006-03-24 11:37) [6]

Кроме ShareMem существуют и альтернативные менеджеры памяти не использующие DLL, например FastMM.


 
Старик   (2006-03-24 12:33) [7]

>>Amoeba
Спасибо, попробую его поюзать :) А он и правда так быстр, как заявлено в названии?


 
KSergey ©   (2006-03-24 16:17) [8]

или еще фанский вариант - пользовать wstring
Для них единый менеджер дельфи пользует из Windows подсистемы COM



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

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

Наверх




Память: 0.48 MB
Время: 0.086 c
2-1145109818
Alex7
2006-04-15 18:03
2006.04.30
Список "Tab Order"


15-1144400144
McSimm
2006-04-07 12:55
2006.04.30
Кстати, может кому-то интересно все-таки решить кто не знает.


2-1145022199
my_sweet
2006-04-14 17:43
2006.04.30
удаление данных из файла *. db


15-1144410907
kas
2006-04-07 15:55
2006.04.30
США или Россия?


2-1144834953
UKRSHEV
2006-04-12 13:42
2006.04.30
Доступ к URL, требующим авторизации.