• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            [轉]windows消息機制

            windows消息機制

            一 Windows中有一個系統消息隊列,對于每一個正在執行的Windows應用程序,系統為其建立一個“消息隊列”,即應用程序隊列,用來存放該程序可能創建的各種窗口的消息。應用程序中含有一段稱作“消息循環”的代碼,用來從消息隊列中檢索這些消息并把它們分發到相應的窗口函數中。

            o_windowsmessage2.jpg

            二 Windows為當前執行的每個Windows程序維護一個「消息隊列」。在發生輸入事件之后,Windows將事件轉換為一個「消息」并將消息放入程序的消息隊列中。程序通過執行一塊稱之為「消息循環」的程序代碼從消息隊列中取出消息:
            while(GetMessage (&msg, NULL, 0, 0))???????
            {????????
            ??? TranslateMessage (&msg) ;????????
            ??? DispatchMessage (&msg) ;???????
            }

            msg變量是型態為MSG的結構,型態MSG在WINUSER.H中定義如下:
            typedef struct tagMSG???????
            {???????
            ??? HWND?? hwnd ;????????
            ??? UINT?? message ;????????
            ??? WPARAM wParam ;????????
            ??? LPARAM lParam ;????????
            ??? DWORD? time ;????????
            ??? POINT? pt ;???????
            }???????
            MSG, * PMSG ;
            ??????
            POINT數據型態也是一個結構,它在WINDEF.H中定義如下:
            typedef struct tagPOINT???????
            {???????
            ??? LONG? x ;???????
            ??? LONG? y ;???????
            }???????
            POINT, * PPOINT;
            TranslateMessage(&msg);?將msg結構傳給Windows,進行一些鍵盤轉換。(關于這一點,我們將在第六章中深入討論。)
            DispatchMessage(&msg);又將msg結構回傳給Windows。然后,Windows將該消息發送給適當的窗口消息處理程序,讓它進行處理。這也就是說,Windows將呼叫窗口消息處理程序。在HELLOWIN中,這個窗口消息處理程序就是WndProc函數。處理完消息之后,WndProc傳回到Windows。此時,Windows還停留在DispatchMessage呼叫中。在結束DispatchMessage呼叫的處理之后,Windows回到HELLOWIN程序中,并且接著從下一個GetMessage呼叫開始消息循環。
            ????????
            三 隊列化消息與非隊列化消息
            ????
            消息能夠被分為「隊列化的」和「非隊列化的」。隊列化的消息是由Windows放入程序消息隊列中的。在程序的消息循環中,重新傳回并分配給窗口消息處理程序。非隊列化的消息在Windows呼叫窗口時直接送給窗口消息處理程序。也就是說,隊列化的消息被「發送」給消息隊列,而非隊列化的消息則「發送」給窗口消息處理程序。任何情況下,窗口消息處理程序都將獲得窗口所有的消息--包括隊列化的和非隊列化的。窗口消息處理程序是窗口的「消息中心」。

            隊列化消息基本上是使用者輸入的結果,以擊鍵(如WM_KEYDOWN和WM_KEYUP消息)、擊鍵產生的字符(WM_CHAR)、鼠標移動(WM_MOUSEMOVE)和鼠標按鈕(WM_LBUTTONDOWN)的形式給出。隊列化消息還包含時鐘消息(WM_TIMER)、更新消息(WM_PAINT)和退出消息(WM_QUIT)。

            非隊列化消息則是其它消息。在許多情況下,非隊列化消息來自呼叫特定的Windows函數。例如,當WinMain呼叫CreateWindow時,Windows將建立窗口并在處理中給窗口消息處理程序發送一個WM_CREATE消息。當WinMain呼叫ShowWindow時,Windows將給窗口消息處理程序發送WM_SIZE和WM_SHOWWINDOW消息。當WinMain呼叫UpdateWindow時,Windows將給窗口消息處理程序發送WM_PAINT消息。鍵盤或鼠標輸入時發出的隊列化消息信號,也能在非隊列化消息中出現。例如,用鍵盤或鼠標選擇了一個菜單項時,鍵盤或鼠標消息就是隊列化的,而說明菜單項已選中的WM_COMMAND消息則可能就是非隊列化的。

            四 SendMessage()與PostMessage()之間的區別是什么?
            它們兩者是用于向應用程序發送消息的。PostMessagex()將消息直接加入到應用程序的消息隊列中,不等程序返回就退出;而SendMessage()則剛好相反,應用程序處理完此消息后,它才返回。我想下圖能夠比較好的體現這兩個函數的關系:

            o_postmessage.gif


            五 函數peekmessage和getmessage的區別?

            兩個函數主要有以下兩個區別:
            1.GetMessage將等到有合適的消息時才返回,而PeekMessage只是撇一下消息隊列。
            2.GetMessage會將消息從隊列中刪除,而PeekMessage可以設置最后一個參數wRemoveMsg來決定是否將消息保留在隊列中。

            posted on 2006-12-28 16:36 永遇樂 閱讀(1390) 評論(0)  編輯 收藏 引用 所屬分類: Windows MFC

            <2006年12月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            常用鏈接

            留言簿(6)

            隨筆分類

            推薦Blog

            友情鏈接

            搜索

            最新評論

            閱讀排行榜

            精品国产91久久久久久久a| 一本久久综合亚洲鲁鲁五月天| 亚洲人AV永久一区二区三区久久 | 亚洲伊人久久精品影院| 91亚洲国产成人久久精品| 国产午夜久久影院| 狠狠狠色丁香婷婷综合久久五月| 麻豆成人久久精品二区三区免费| 精品久久久久久无码不卡| 精品久久久一二三区| 国产免费久久精品99re丫y| 伊人久久大香线蕉无码麻豆| 久久人人爽人爽人人爽av| 欧美久久久久久精选9999| 久久亚洲av无码精品浪潮| 日韩久久无码免费毛片软件| 香蕉aa三级久久毛片| 中文字幕无码久久精品青草 | 久久AV无码精品人妻糸列| 亚洲香蕉网久久综合影视| 一本色道久久88—综合亚洲精品| 亚洲va国产va天堂va久久| 亚洲国产精品成人久久| 日韩亚洲欧美久久久www综合网| 欧美伊香蕉久久综合类网站| 久久99精品久久久久久野外| 少妇无套内谢久久久久| 国产精品久久亚洲不卡动漫| 久久亚洲欧洲国产综合| 久久人妻少妇嫩草AV蜜桃| 好久久免费视频高清| 亚洲精品tv久久久久久久久久| 亚洲精品无码久久一线| 国产99久久久久久免费看| 一本久久a久久精品亚洲| 日韩亚洲欧美久久久www综合网 | 思思久久好好热精品国产| 久久久女人与动物群交毛片| 久久夜色精品国产| 精品国产福利久久久| 久久免费观看视频|