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

Вниз

Проблемы с памятью   Найти похожие ветки 

 
Кирилл Усов   (2002-07-10 11:21) [0]

Здравствуйте господа! Может, кто-то знает ответ на такой вопрос:
Приложение работает с БД Interbase. Есть DataModule, где находится tDatabase. Во время разработки, когда я добавляю новые ttable и на tquery на формы, связывая их с tDatadase, он ессно открывает сеанс с реальной БД. После нескольких часов работы при очередной компиляции выдается ошибка: "Alias db1: Unsufficiant memory for this operation"! И удаляется такая ошибка только выходом из сеанса. не помогает ни закрытие Дельфи, ни рестарт Сервера. неужели действительно так плохо используется память, не освобождаясь после работы? Подскажите, как это ликвидировать! Если решение будет удачным, с меня пыво!:)


 
Толик ©   (2002-07-10 12:10) [1]

Это всё из-за BDE. Такое происходит в случае, когда в программе не происходит прямо или косвенно вызов TDatabase.Close(). Например, если программа закрывается из под отладчика через Run-ProgramReset (Ctrl + F2). Отсюда и выводы:
1. Закрывать открытые TDatabase
2. Если уж такое произошло, то закрыть все BDE-использующие приложения.
Надеюсь, что данное решение будет удачным - очень уж пивка хочется :)


 
Игорь Шевченко ©   (2002-07-10 12:21) [2]

Перед сохранением проекта установите Database.Active в false


 
Кирилл Усов   (2002-07-10 13:45) [3]

Спасибо за советы!
Т.е. получается, что если у меня постоянно во время разработки идет обращение к tDatabase(создаю ttable и tquery, например), то такая ошибка будет неизбежна? Может быть надо как-то(подскажите как?) выделять больше памяти под BDE?
толик, утомительно уж каждые 10 мин обращаться к tDatabase и закрывать его:(


 
Eugene Lachinov ©   (2002-07-10 13:54) [4]

Попробуй увеличить SHAREDMEMSIZE в BDE Adminе на странице Configuration-Init


 
Толик ©   (2002-07-10 14:32) [5]

to Кирилл Усов:
Не совсем так. Речь идёт о том, что каждому TDatabase.Open() должен соответствовать свой TDatabase.Close() (точнее BDE-шные ф-и, которые там вызываются). В данном случае происходит типичная утечка ресурсов: выделяем - забываем(не можем) закрыть - выделяем снова.
TDatabase м.б. открыт сколь угодно долго, главное - его закрыть ПОТОМ, когда он больше не нужен.


 
Skier ©   (2002-07-10 14:37) [6]


> каждому TDatabase.Open() должен соответствовать свой TDatabase.Close()
>


Присоединяюсь.
Вообще в данном случае это можно сравнить с объектом.
1. Создали объект. 2. Поработали с ним 3. Убили объект чтобы
не кушать память без надобности.

>Кирилл Усов
Ещё можно посмотреть MAXFILESHANDLES на странице Configuration-Init



 
Кирилл Усов   (2002-07-10 14:40) [7]

Куда пыво высылать?


 
Игорь Шевченко ©   (2002-07-10 14:43) [8]

Кирилл Усов (10.07.02 14:40)

Сам на радостях выпей :-)



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

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

Наверх




Память: 0.48 MB
Время: 0.009 c
3-70656
NaPoleOn_IV
2002-06-20 21:49
2002.07.22
Как экспортировать содержимое DBEdit в Excel в определенную ячейк


1-70797
Smok_er
2002-07-09 09:47
2002.07.22
Система проговаривания времени


1-70762
Doctor Deejay
2002-07-02 21:54
2002.07.22
Меню, созданное динамически


1-70769
EugenCFG
2002-07-09 11:29
2002.07.22
RxCheckListBox1


3-70658
ize
2002-07-02 11:32
2002.07.22
DBGrid + ADOTable