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

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久无码高潮喷水| 欧美综合天天夜夜久久| 狠狠狠色丁香婷婷综合久久五月| 色综合久久久久久久久五月| 亚洲AV无码一区东京热久久 | 国产呻吟久久久久久久92| 久久婷婷五月综合国产尤物app| 久久久国产一区二区三区| 精品久久久久久中文字幕| 久久99热国产这有精品| 久久99精品久久久久久动态图| 东京热TOKYO综合久久精品| 精品多毛少妇人妻AV免费久久| 国产农村妇女毛片精品久久| 久久久久亚洲?V成人无码| 性高朝久久久久久久久久| 欧美亚洲国产精品久久| 久久99热精品| 欧美噜噜久久久XXX| 99久久国产综合精品五月天喷水 | 一级A毛片免费观看久久精品| 久久99国产亚洲高清观看首页| 久久久久99精品成人片三人毛片 | 久久激情亚洲精品无码?V| av午夜福利一片免费看久久| 无遮挡粉嫩小泬久久久久久久 | 久久久久久亚洲Av无码精品专口| 国内精品久久久久| 日韩久久久久久中文人妻| 99久久国产免费福利| 国产真实乱对白精彩久久| 久久99国产精品99久久| 国产精品狼人久久久久影院| 精品久久久无码人妻中文字幕| 一本久久a久久精品vr综合| 很黄很污的网站久久mimi色 | 99久久免费国产精精品| 久久亚洲中文字幕精品一区| 久久久久97国产精华液好用吗| 久久久无码精品亚洲日韩软件| 亚洲精品高清国产一线久久|