• Курсы Академии Кодебай, стартующие в мае - июне, от команды The Codeby

    1. Цифровая криминалистика и реагирование на инциденты
    2. ОС Linux (DFIR) Старт: 16 мая
    3. Анализ фишинговых атак Старт: 16 мая Устройства для тестирования на проникновение Старт: 16 мая

    Скидки до 10%

    Полный список ближайших курсов ...

Разбухание кэша программы при ошибочном Sql-запросе к БД

  • Автор темы sergushkin
  • Дата начала
S

sergushkin

Помогите пожалуйста разобраться со следующей проблемой.
Перепробовал MySQL, MS SQL Server. Подключался через BDE, ADO.
Для тестирование в цикле выполняю ошибочный запрос к БД. При этом идет рабухание программы.
Но если окно программы свернуть в таскбар и востановить, то память, занимаемая программой, уменьшается. Можно ли от этого избавиться либо есть ли команда сброса буферов кэша программы?
 
S

sergushkin

Данная функция не помогает. Идёт реальная утечка памяти.
См.
 
S

sergushkin

Я разобрался в этой проблеме. Загвоздка оказалась в обрабоки исключительных ситуаций.
При возникновении эксепшена сознается соответстующий класс дочерний к Exception. И если его не обработа в секции catch, а указать просто catch(...), то память, выделенная под класс эксепшена не освобождается. Таким образов в ADO следует обработать EOleException, а в BDE - EDBEngineError
 
Мы в соцсетях:

Обучение наступательной кибербезопасности в игровой форме. Начать игру!