Пятница, 17 Май 2024, 18:52
Uchi.ucoz.ru
Меню сайта
Форма входа

Категории раздела
Высшая математика [11]
Экономическая социология [95]
Основы Менеджмента [64]
Бухгалтерский учёт [157]
Философия [163]
Мировая Экономика [603]
Бизнес планирование [29]
Финансирование и кредитование инвест [105]
Ценообразование [46]
Гражданское право [196]
Права Человека [173]
Основы Маркетинга [207]
Основы энергосбережения [55]
Информатика [0]
Экология и устойчивое развитие [0]
Физика для студентов [0]
Основы права [0]
Политология [0]
Не стандартные примеры на Delphi [169]
Примеры на Delphi7 [108]
Алгоритмы [94]
API [110]
Pascal [152]
Базы Данных [6]
Новости
Чего не хватает сайту?
500
Статистика
Зарегистрировано на сайте:
Всего: 51636


Онлайн всего: 17
Гостей: 17
Пользователей: 0
Яндекс.Метрика
Рейтинг@Mail.ru

Каталог статей


Главная » Статьи » Студентам » Не стандартные примеры на Delphi

Корректное закрытие базы данных приложением Delphi
Очень интересный и полезный вопрос!! Я сам так с ним до конца и не
разобрался! Но я попробую систематизировать события, происходящие при запросе на
завершение работы Windows:

Windows посылает сообщение WM_QUERYENDSESSION главным окнам всех запущенных
приложений, при этом приложения должно сообщить свою готовность к завершению
работы.
Если при этом хотя бы одно из приложений ответит отрицательно, Windows
прерывает процесс завершения работы.

Delphi перехватывает это сообщение, и, в свою очередь, вызывает метод
TForm.CloseQuery, (в главной форме, естественно), который генерирует событие
OnCloseQuery, в обработчике которого можно указать на неготовность завершения
приложения и отмены завершения работы Windows.

Если я правильно понимаю, если ваше приложение "не мешает" Windows завершить
свою работу, Windows нормально НЕ завершает работу приложения, поскольку для
этого нет необходимости, не нужно освобождать память, ресурсы и пр. Так, если
это утверждение верно (это легко можно проверить, но я слишком ленив сейчас), то
событие OnCloseQuery - ваш единственный шанс сохранения данных на диске. Я не
думаю что эта логика слишком плоха, просто это одна из тех причуд Windows,
которую нужно знать и пользоваться ею. Что может произойти в описанном выше
сценарии: редактируемая в настоящий момент запись не будет отправлена (Post) в
базу данных, но та же самая вещь может случиться и при нормальном завершении
приложения.
При выходе из windows, вы вызываете WM_CLOSE api (или что-то типа этого) для
каждого работающего в настоящий момент приложения. Программа закрывается точно
таким же образом, как если бы вы щелкнули на кнопке закрытия или вызвали close
из главной формы. Поэтому вам не нужно предпринимать никаких дополнительный
действий, связанных с завершением работы с таблицами.
Категория: Не стандартные примеры на Delphi | Добавил: Lerka (22 Ноя 2012)
Просмотров: 390 | Рейтинг: 1.0/ 5 Оштрафовать | Жаловаться на материал
Похожие материалы
Всего комментариев: 0

Для блога (HTML)


Для форума (BB-Code)


Прямая ссылка

Профиль
Пятница
17 Май 2024
18:52


Вы из группы: Гости
Вы уже дней на сайте
У вас: непрочитанных сообщений
Добавить статью
Прочитать сообщения
Регистрация
Вход
Улучшенный поиск
Поиск по сайту Поиск по всему интернету
Наши партнеры
Интересное
Популярное статьи
Портфолио ученика начальной школы
УХОД ЗА ВОЛОСАМИ ОЧЕНЬ ПРОСТ — ХОЧУ Я ЭТИМ ПОДЕЛИТ...
Диктанты 2 класс
Детство Л.Н. Толстого
Библиографический обзор литературы о музыке
Авторская программа элективного курса "Практи...
Контрольная работа по теме «Углеводороды»
Поиск
Главная страница
Используются технологии uCoz