Главная страница
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.013 c
3-70640
TAN_K
2002-07-01 14:51
2002.07.22
РАБОТА С БАЗАМИ ДАННЫХ


14-70903
Pill
2002-06-23 11:57
2002.07.22
ищу компонент для построения трехмерных графиков


14-70895
Роман Василенко
2002-06-21 10:39
2002.07.22
Ищу братьев по разуму (Advantage TDataset Descendant)


3-70635
ASM
2002-07-01 15:20
2002.07.22
FormattedMemo?


3-70617
ADO
2002-06-30 19:48
2002.07.22
Можно ли в DBGrid запретить вставку новых строк, и при этом....