• <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>
            posts - 16,  comments - 34,  trackbacks - 0
            LRESULT CallNextHookEx(HHOOK hhk,int nCode,WPARAM wParam,LPARAM lParam);

             

            hhk [in]
            Windows 95/98/ME: Handle to the current hook. An application receives this handle as a result of a previous call to the SetWindowsHookEx function.
            Windows NT/XP/2003: Ignored.


            什么時候多了一條“Windows NT/XP/2003: Ignored.”???

            以前看到一直是
            “Identifies the current hook. An application receives this handle as a result of a previous call to the SetWindowsHookEx function. ”
            但再翻翻VS2005和2008的文檔、網絡或者離線MSDN全都統一口徑說,“Windows NT/XP/2003: Ignored.”
            還逮不到M$的把柄了……

            改天裝個VC6的文檔看看CallNextHookEx是怎么說的……  難道真是我記錯了?


             

            本來么,Windows的很多回調函數就設計得有缺陷——缺少一個狀態維持的參數,比如void* user_data

            最常見的WndProc就是一例。
            一旦一個特定的WndProc需要同時作為幾個窗口的處理函數,不使用靜態變量(包括global和static)幾乎是不可能辦到的事情。
            Charles Petzold的《Programming Windows》當中都不乏這樣的例子:需要讓一個WndProc處理多個窗口,而不得不使用全局變量。


            如果作為最終開發人員,當然有權使用每個hWnd的USER_DATA。但是庫不可以這樣做。
            所以庫們想了各種各樣的辦法,主要包括以MFC和wxwidgets為代表的全局映射表,和WTL/ATL為代表的thunk,來解決WndProc的問題。


            而在這些有缺陷的回調函數中,最嚴重的就是所有的HookProc。
            要求你在HookProc當中以SetWindowsHookEx的返回值為第1個參數調用CallNextHookEx,卻不把這個參數傳遞給你!
            回調函數啊!調用者都不傳,這不是逼人用全局變量么?
            雪上加霜的是,它還涉及到了地址空間的問題,全局變量還要放在共享節里才可以。
            真是……



            本來打算設計一套機制解決這個問題的。可是M$已經悄悄的忽略了CallNextHookEx的第1個參數……

            posted on 2009-03-04 22:53 OwnWaterloo 閱讀(1679) 評論(2)  編輯 收藏 引用

            FeedBack:
            # re: 在WinNT上CallNextHookEx忽略第1個參數
            2009-03-05 00:49 | 陳梓瀚(vczh)
            反正,HWND被映射到一個類指針,這張表寫在全局變量里面。HOOK拿到了HWND,去找表,然后找到你自己的類,類里面就有一堆user data了。

            所以,只需要一張表。  回復  更多評論
              
            # re: 在WinNT上CallNextHookEx忽略第1個參數
            2009-03-05 13:38 | OwnWaterloo
            @陳梓瀚(vczh)
            老兄 你說的是WndPorc吧? WndPorc拿到HWND,然后去查表找this。
            上面說了,這是MFC和wxwidgets處理WndProc的方式。

            對于HOOK,即使通過LPARAM轉型到XXXStruct,拿到一個HWND,也不能保證就有user data。
            比如,程序已經是別人寫好了,根本無法知道他是否有表。
            這時候,就必須HOOK自己想辦法找user data了。  回復  更多評論
              
            <2009年4月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            常用鏈接

            留言簿(8)

            隨筆檔案(16)

            鏈接

            搜索

            •  

            積分與排名

            • 積分 - 198663
            • 排名 - 134

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲综合婷婷久久| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久久久亚洲AV成人网人人软件| 性做久久久久久久| 国产V亚洲V天堂无码久久久| 大伊人青草狠狠久久| 欧美久久久久久午夜精品| 一本色道久久综合狠狠躁篇 | 久久综合综合久久97色| 久久精品国产99久久久| 国产精品久久免费| 婷婷国产天堂久久综合五月| 人妻无码久久一区二区三区免费 | 久久国产热精品波多野结衣AV | 久久99中文字幕久久| 亚州日韩精品专区久久久| 99久久99这里只有免费费精品| 久久久久久A亚洲欧洲AV冫| 久久成人国产精品二三区| 久久男人Av资源网站无码软件| 久久精品亚洲乱码伦伦中文| 久久久久久久国产免费看| 久久强奷乱码老熟女| 亚洲精品成人久久久| 亚洲精品美女久久久久99小说| 久久99国产精品一区二区| 7国产欧美日韩综合天堂中文久久久久 | 久久天天躁狠狠躁夜夜不卡| 久久国产亚洲精品| 亚洲中文久久精品无码ww16| 国产激情久久久久久熟女老人| 久久综合久久综合亚洲| 久久夜色精品国产噜噜亚洲AV | 亚洲精品乱码久久久久久蜜桃不卡 | 久久99国产综合精品女同| 国内精品久久久久久不卡影院| 伊人久久大香线蕉综合热线| 国内精品久久人妻互换| 久久久久人妻一区精品| 99久久精品国产一区二区蜜芽| 久久久国产视频|