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

            Beginning to 編程

            VC++ 方面編程文章

             

            結構化設計的救命稻草-回調機制 / 轉 Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=253623

            摘要:開發模式的確立是軟件開發過程中不可缺少的一部分,就目前來說,面向過程和面向對象是兩種主要的設計方法,雖然面向對象OOP是比較流行的字眼,但不表示面向過程就一定好無作為,畢竟面向過程設計方法也有適合其應用的軟件系統:以功能操作為主,擴展性要求不高,無需過多考慮復用以及軟件的通用性能。那是不是面向過程的設計方法對于諸如系統框架擴展問題就絲毫沒有辦法了呢?

            按照面向過程的基本原則,劃分系統功能模塊、模塊細分到函數、生成系統整體的結構模型,似乎在整個過程中沒有任何東西可以用來提供系統擴展,其實解決的方法還是有的,這根救命稻草就是回調機制。

            一談到回調機制,當然就少不了我們的主角:系統API(通常都是)和回調函數,這兩者缺一不可。其實回調的基本思想就是由系統給我們提供一些接口,也就是常使用的API,這種函數可以將某個其他函數的地址作為其參數之一,而且可以利用該地址對這個函數進行調用,而被調用的函數就是我們通常所說的回調函數了。
            下面給個回調函數使用的小例子:
            ------------------------------------------
            //相當于我們提到的系統API
            mainFunc( void*  userFunc )//當然參數不會這么簡單,只是模擬
            {
             while (...)
             {
              printf("ok!");
                            //調用回調函數了
              if (userFunc!=NULL) 
               userFunc();
             }
            }
            可以看出MainFunc可以根據函數userFunc的地址調用它。
            ------------------------------------------
            這樣使用者只需要定義一個函數:void myFunc(),然后按照mainFunc(&myFunc)(&只表示傳遞的是函數的地址,無具體含義),就可以讓我們的mainFunc來調用myFunc從而實現相應的功能,這樣當然可以完成我們預期的目的-擴展現有系統。

            在windows系統中,支持這種回調機制的系統API不占少數,像實現ListControl排序的SortItem()函數,還有操作Font使用的函數EnumFontFamilies()都有提供這種回調機制,使得我們的用戶有機會添加自己期望的功能實現。當然,使用回調函數并不是一個輕松的事情,如果我們的系統中存在了大量的回調函數是很難管理的,這個就與系統中存在大量全局變量一樣,出現多個函數爭相訪問同一個變量我們就很難使用簡單的邏輯來處理,容易陷入混亂,因此,盡管回調機制可以在某種程度上達到我們的目的,但切不可亂加使用,不然后果很難預料。

            當然至于詳細的回調函數實現,還需要大家潛心研究,這里我只是總結一下:
            1 回調函數是由開發者按照一定的原型進行定義的函數(每個回調函數都必須遵循這個原型來設計)

            例如:
            ------------------------------------------
            BOOL CALLBACK DialogProc(
                
                 HWND hwndDlg, // handle of dialog box
                 UINT uMsg, // message
                 WPARAM wParam, // first message parameter
                 LPARAM lParam // second message parameter
                 );
            ------------------------------------------
            說明:
            回調函數必須有關鍵詞 CALLBACK
            回調函數本身必須是全局函數或者靜態函數,不可定義為某個特定的類的成員函數

            2 回調函數并不由開發者直接調用執行(只是使用系統接口API函數作為起點)
            3 回調函數通常作為參數傳遞給系統API,由該API來調用
            4 回調函數可能被系統API調用一次,也可能被循環調用多次(SortItem就是自調用)

            最后說句題外話,其實windows系統中還有另一種機制-消息機制,也是一個比較不錯的工具,能夠為很多實際的問題提供解決方法,這個以后再總結了。

            posted on 2006-03-09 11:27 Beginning to 編程 閱讀(470) 評論(0)  編輯 收藏 引用 所屬分類: 程序摘錄

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類

            隨筆檔案

            文章檔案

            相冊

            BlogDev

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久久久99精品成人片试看| 久久久婷婷五月亚洲97号色| 国产精品热久久毛片| 99久久精品国产一区二区三区| 色偷偷888欧美精品久久久| 国产精品VIDEOSSEX久久发布| 蜜桃麻豆www久久国产精品| 久久国产免费直播| 国产精品综合久久第一页| 亚洲另类欧美综合久久图片区| 九九精品99久久久香蕉| 久久婷婷五月综合成人D啪| 久久人人爽人人爽人人片av高请| 久久久久久亚洲精品不卡| 色婷婷综合久久久中文字幕| 久久se精品一区二区影院| 久久偷看各类wc女厕嘘嘘| 日韩久久无码免费毛片软件| 国内精品久久久人妻中文字幕| 亚洲国产成人久久精品99| 久久99精品国产99久久| 狠狠色婷婷久久一区二区| 久久久久亚洲精品中文字幕| 麻豆精品久久精品色综合| 性色欲网站人妻丰满中文久久不卡| 国产成人精品久久综合| 四虎国产精品免费久久5151| 久久精品亚洲日本波多野结衣| 思思久久99热只有频精品66| 欧美麻豆久久久久久中文| 女人香蕉久久**毛片精品| 97久久综合精品久久久综合 | 久久国产免费观看精品3| 2021最新久久久视精品爱| 久久久久亚洲AV无码专区桃色| 国产精品gz久久久| 久久嫩草影院免费看夜色| 亚洲AⅤ优女AV综合久久久| 人人狠狠综合88综合久久| 久久亚洲AV成人无码软件| 国产成人久久精品一区二区三区|