Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Основная";
Текущий архив: 2002.07.22;
Скачать: [xml.tar.bz2];

Вниз

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

 
Кирилл Усов   (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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.005 c
1-70726
avr555
2002-07-10 20:47
2002.07.22
Поиск и замена в Word е


14-70884
cpp
2002-06-25 09:36
2002.07.22
Нужен компонент для работы с графикой (или алгоритмы)


3-70609
ruslan_as
2002-06-30 12:27
2002.07.22
Поле-счетчик в ClientDataSet1


1-70822
eruc
2002-07-09 17:51
2002.07.22
string ???


3-70665
_dron_
2002-07-02 13:01
2002.07.22
Создать запрос к 2-м базам Interbase и dbase. Они имеют общие пол





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский