• <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 永遇樂 閱讀(1397) 評論(0)  編輯 收藏 引用 所屬分類: Windows MFC

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

            導航

            統計

            常用鏈接

            留言簿(6)

            隨筆分類

            推薦Blog

            友情鏈接

            搜索

            最新評論

            閱讀排行榜

            2021国内久久精品| 秋霞久久国产精品电影院| 94久久国产乱子伦精品免费| 18岁日韩内射颜射午夜久久成人 | 欧美成a人片免费看久久| 久久婷婷色香五月综合激情| 亚洲综合日韩久久成人AV| 久久亚洲国产中v天仙www| 国产99久久久国产精品小说| 国产精品久久久久无码av| 久久av高潮av无码av喷吹| 久久久久亚洲精品日久生情 | 精品多毛少妇人妻AV免费久久| 亚洲人成伊人成综合网久久久| 久久国产精品二国产精品| 亚洲精品视频久久久| 亚洲国产精品婷婷久久| 日韩精品久久久肉伦网站| 亚洲精品无码久久久久AV麻豆| 精品999久久久久久中文字幕| 久久久久久精品免费看SSS| 久久国产精品免费一区二区三区| 久久综合香蕉国产蜜臀AV| 一级做a爰片久久毛片毛片| 99国内精品久久久久久久| 国产精品免费看久久久| 亚洲人成无码www久久久| 久久综合精品国产一区二区三区| 99久久精品免费国产大片| 久久精品一区二区| 久久精品国产影库免费看| 午夜久久久久久禁播电影| 777午夜精品久久av蜜臀| 久久99精品久久久大学生| 久久国产AVJUST麻豆| 久久精品国产亚洲AV忘忧草18| 亚洲精品tv久久久久| 亚洲欧洲日产国码无码久久99| 中文字幕无码精品亚洲资源网久久| 奇米影视7777久久精品人人爽| 亚洲国产精品综合久久一线|