• <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

            友情鏈接

            搜索

            最新評論

            閱讀排行榜

            久久综合精品国产一区二区三区 | 91精品国产91热久久久久福利| 久久精品aⅴ无码中文字字幕重口| 无码人妻久久一区二区三区免费丨 | 亚洲精品乱码久久久久久蜜桃 | 久久精品国产一区| 国产99久久九九精品无码| 久久精品无码一区二区三区免费 | 国产精品久久久久久影院| 久久涩综合| 99re久久精品国产首页2020| 久久夜色撩人精品国产小说| 97久久超碰国产精品旧版| 亚洲国产成人久久综合一区77| 久久久亚洲欧洲日产国码二区| 国産精品久久久久久久| 精品久久久久久亚洲精品| 亚洲国产日韩综合久久精品| 精品久久久久久综合日本| 国产成人精品综合久久久| 久久久精品波多野结衣| 久久久久国产精品| 成人妇女免费播放久久久| 2021久久精品免费观看| 久久综合九色欧美综合狠狠| 久久久久国产精品| 国产精品久久自在自线观看| 久久久久av无码免费网| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 久久精品国产影库免费看 | 97精品依人久久久大香线蕉97| 久久综合伊人77777麻豆| segui久久国产精品| 亚洲成人精品久久| 国产亚州精品女人久久久久久 | 欧美久久久久久| 午夜精品久久久久久影视777| 国产精品欧美亚洲韩国日本久久| 日本精品久久久中文字幕| 欧美伊香蕉久久综合类网站| 精品午夜久久福利大片|