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

            C++ Programmer's Cookbook

            {C++ 基礎(chǔ)} {C++ 高級} {C#界面,C++核心算法} {設(shè)計模式} {C#基礎(chǔ)}

            事件和回調(diào)

            事件和回調(diào)


            Ken Bergmenn
            MSDN開發(fā)組

            什么時候使用一個事件(或連接點)接口以及什么時候使用特定的回調(diào)接口是很難理解的。他們有點類似,但在很多方面還是有很大的差異。下面將概述一些基本問題,這些基本問題在試圖決定如何繼續(xù)進行你的組件時是應(yīng)該考慮到的。

            我認(rèn)識你嗎?

            事件接口和回調(diào)接口之間關(guān)鍵的概念差異是事件被設(shè)計得更象一個匿名廣播,而回調(diào)函數(shù)則更象一個"握手"聯(lián)絡(luò)方式。雖然其他重要問題也需要闡明,但是關(guān)于使用哪一個技術(shù)關(guān)鍵決定于匿名性。

            開始熟悉

            任意對一個事件源有訪問的對象都能通過簡單地把那個索引放進WithEvents變量來處理源提出的事件。在C++中處理連接點與之有相當(dāng)?shù)年P(guān)聯(lián),但是前提是一樣的。在任意一種情況下,事件源對什么對象可能正在處理自己的事件沒有任何概念??赡苡性S多個對象正與之密切相連但也可能一個也沒有。關(guān)鍵之處是事件源盲目地通知每一個被連接的客戶機通過它的事件連接點接口,但并不知道是否客戶機正在執(zhí)行處理事件。

            相反地,一個設(shè)計用來執(zhí)行回調(diào)的服務(wù)器必須有一個明顯的對每個需要通知的對象的訪問,它必須連接和管理這些訪問,而且最后它還必須執(zhí)行通知?;旧?,服務(wù)器必須清楚地知道有多少個客戶機以及如何與他們中的每一個連接和交互。

            事件順序

            在Microsoft Visual Basic事件接口中,一個事件源不能控制客戶機接受他們的事件的順序。這話反之也是正確的??蛻魴C不能肯定與別的客戶機相比用一種特定的順序接受通知。即使你要在C++中滾動你自己的連接點,后者也是正確的。

            另一方面,一個回調(diào)服務(wù)器必須控制它調(diào)回客戶機的順序。當(dāng)然,在一個回調(diào)服務(wù)器上做這些工作會有好處。比如,一個源服務(wù)器可能被設(shè)計用來給某些客戶機高優(yōu)先級的通知,或它可能執(zhí)行一些特定的基于回調(diào)結(jié)果的動作。這個靈活性在下一點中將更有意義。

            誰負(fù)責(zé)

            當(dāng)事件服務(wù)器提出一個事件,它的所有的客戶機都得到了在事件服務(wù)器能重新得到控制之間處理事件的機會。所以,如果許多客戶機都在聽候事件,通知處理將花費難以預(yù)知的時間。另一方面,一個回調(diào)服務(wù)器,因為它對執(zhí)行通知處理負(fù)責(zé),所以在它對客戶機做的每個調(diào)用它都能重新得到控制。

            因為控制級別在這里是有效的,回調(diào)可以采用比事件更靈活的技術(shù)來進行客戶通知。

            現(xiàn)在,讓我們來考慮一下事件的參數(shù)會發(fā)生什么變化。因為事件服務(wù)器直到所有的客戶機都已經(jīng)處理了特定的事件后才能重新得到控制,所有特定客戶機的ByRef參數(shù)的變化已經(jīng)丟失了。只有最后一個客戶機參數(shù)發(fā)生的變化能被事件服務(wù)器看見。當(dāng)考慮到哪一個客戶機被通知的順序不能得到保證的事實時,這確實變得不方便。當(dāng)然,對于回調(diào)服務(wù)器,服務(wù)器對這個處理負(fù)責(zé),所有每一個客戶機的反饋都能被獨立地分析。事實上,一個回調(diào)服務(wù)器可能希望在通知每一個客戶機時傳遞新值。

            處理錯誤

            兩種途徑之間最終的編譯差異在于錯誤的處理方式。如果在一個客戶機的事件處理器中發(fā)生了錯誤,則事件源不會被通知。處理事件的客戶機甚至可能非??膳碌乇罎⒌?,而事件源并不知道,當(dāng)然,客戶機的致命錯誤也只能是使服務(wù)器崩潰(如果它是一個處理中的元件)。在這種情況中,事件服務(wù)器將不知道為什么崩潰,甚至不知道發(fā)生了錯誤。

            當(dāng)然,在任意執(zhí)行問題中,測量你自己的需要的唯一辦法是實驗,基準(zhǔn)和測試。你自己可以試試重排列,并作作數(shù)學(xué)演算。如果你真的想得到絕對的最后速度沖刺,那么做測試是得到保證的唯一方法,而不能相信你曾經(jīng)得到什么樣的承諾。

            posted on 2005-12-08 08:58 夢在天涯 閱讀(976) 評論(0)  編輯 收藏 引用

            公告

            EMail:itech001#126.com

            導(dǎo)航

            統(tǒng)計

            • 隨筆 - 461
            • 文章 - 4
            • 評論 - 746
            • 引用 - 0

            常用鏈接

            隨筆分類

            隨筆檔案

            收藏夾

            Blogs

            c#(csharp)

            C++(cpp)

            Enlish

            Forums(bbs)

            My self

            Often go

            Useful Webs

            Xml/Uml/html

            搜索

            •  

            積分與排名

            • 積分 - 1804603
            • 排名 - 5

            最新評論

            閱讀排行榜

            久久青青草视频| 看全色黄大色大片免费久久久| 久久99热这里只有精品国产| 囯产精品久久久久久久久蜜桃| 久久人爽人人爽人人片AV | 性高朝久久久久久久久久| 国产香蕉久久精品综合网| 久久国产精品-久久精品| 久久久久久国产精品无码下载 | 久久热这里只有精品在线观看| 国产精品久久久久国产A级| 亚洲国产成人精品女人久久久 | 久久精品国产精品亚洲下载| 久久久无码一区二区三区| 久久夜色精品国产www| 久久AV高清无码| 伊人久久精品无码二区麻豆| 色综合久久天天综线观看| 久久青草国产精品一区| 午夜人妻久久久久久久久| 久久无码人妻精品一区二区三区| 国产亚洲婷婷香蕉久久精品| 日韩精品久久久肉伦网站| 老男人久久青草av高清| 欧美日韩精品久久久久| 国产激情久久久久影院小草| 久久被窝电影亚洲爽爽爽| A狠狠久久蜜臀婷色中文网| 欧美精品国产综合久久| 久久久高清免费视频| 亚洲欧美久久久久9999| 亚洲精品午夜国产va久久| 人妻少妇精品久久| 久久这里的只有是精品23| 伊人久久大香线蕉无码麻豆| 性做久久久久久久久| 久久久久久综合网天天| 久久婷婷色综合一区二区| 亚洲成色WWW久久网站| 久久久久亚洲Av无码专| 国产日产久久高清欧美一区|