СТАНДАРТНИЙ ЦИКЛ ОБРОБКИ ПОВІДОМЛЕНЬ

Windows – це ОС, що базується на повідомленнях. Підсистема обміну повідомленнями є ядром ОС, тому знання механізму обробки повідомлень допоможе краще зрозуміти роботу систему та ефективно керувати прикладними програмами. Підхід до побудови програм на основі повідомлень вперше був застосований в ОС для комп’ютерів Macintosh. Він ґрунтується на тому, що поведінка (реакція) програми визначається зовнішніми подіями (повідомлення). Цей факт добре перекликається з концепцією об’єктно-орієнтованого програмування. Тому програмування для Windows за своєю суттю є об’єктно-орієнтованим, навіть якщо використовуються не об’єктно-орієнтовані мови.

Windows – програма складається з множини об’єктів, що обмінюються між собою повідомленнями. Основним об’єктом на якому базується механізм повідомлень є вікно. Воно першим появляється при запуску програми та останнім зникає при її завершенні. В процесі роботи програми ОС повідомляє прикладній програмі, точніше її вікну, про якусь подію за допомогою повідомлення, яке описує зміни, що відбулися в середовищі яке оточує програму. Механізм повідомлень, також єдиний спосіб “спілкування програми зі своїми вікнами. Обмін повідомленнями відбувається через ОС, яка отримавши повідомлення доставляє його відповідному об’єкту (вікну).

Кожне повідомлення зв’язується з певним вікном. З кожним повідомленням у вікні зв’язана програма, що реагує на нього – обробник повідомлень. Кожне повідомлення ОС розміщає в первинну чергу повідомлень з якої повідомлення розподіляються між об’єктами. В Win32 (на відміну від Win16, де існує тільки черга) може створюватися черга повідомлень для кожного процесу а також потоку, що позитивно позначається на швидкості та надійності виконання програм. В межах вікна існують механізми обміну повідомленнями, які дозволяють обійти загальну чергу повідомлень, що розвантажую загальну чергу та пришвидшує виконання прикладних програм.

До загальних функцій розсилання повідомлень відносяться:

SengMessage() – посилає повідомлення об’єктові на пряму та очікує його опрацювання (синхронний обмін);

PostMessage() – посилає повідомлення в чергу та завершується (синхронний обмін).

Варто зауважити, що функція SengMessage() дещо обходить механізм обміну повідомленнями ОС Windows.

Стандартний цикл обробки повідомлень в основній функції програми має вигляд:

 

while (GetMessage(&msg, NULL, 0, 0)) {

TranslateMessage(&msg);

DispatchMessage(&msg);

}

 

Цей цикл працює протягом всього часу роботи програми. Кожна ітерація – це видобування одного повідомлення з черги повідомлень біжучого потоку, за що відповідає функція GetMessage(), другий аргумент котрої (NULL) вказує, що обробляються повідомлення для всіх вікон. Третій та четвертий параметри задають фільтр повідомлень (min, max). Вибране повідомлення помішається в спеціальну структуру MSG:

 

typedef struct tagNSG {

HWND hWnd;

UINT message;

WPARAM wParam;

LPARAM lParam;

DWORD time;

POINT pt;

} MSG;

 

де hWnd – (дескриптор) логічний номер вікна, якому адресується повідомлення; message – ідентифікатор (номер) повідомлення; wParam і lParam – додаткові дані повідомлення, їх наповнення залежать від типу повідомлення; time - час посилання повідомлення; pt - положення курсору миші в час посилання повідомлення.

Функція TranslateMessage() призначена для перетворення віртуальних кодів клавіатури в ASCII – коди, що дозволяє розрізняти великі та малі літери без додаткового аналізу стану клавіш регістру.

Функція DispatchMessage() призначена для передачі повідомлення у відповідну віконну процедуру для обробки.

Функція GetMessage() завжди повертає істинне значення окрім одного випадку. Прийнявши повідомлення WM_QUIT вона завершується з кодом FALSE і цикл завершується.

Отже цикл обробки повідомлень є основою будь-якої програми Windows.