• <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 - 58,  comments - 75,  trackbacks - 0
            Boost.Function庫用來提供一個對象化的函數指針。

            函數指針對設計很有用。它使調用者可以延期調用,調用時機由調用者確定。而且可以改變
            響應者,以應對不同的要求。

            C中的函數指針只能用于自由函數。在C++中除了自由函數還有函數對象和類成員函數,這些
            C的函數指針是無法用的。這要求能適應C++語言的函數指針。既然C++語言本身沒有提供,
            那就提供一個庫。stl提供了,但是定義了很多類型,使用起來并不是很方便,而且函數參數
            的個數被限定在兩個以下,更能是備受限制。Boost.Function庫提供了一個好的解決方案。

            Boost.Function庫可以支持自由函數,函數對象,類成員函數。而且參數個數多達10個。
            Boost.Function庫利用模板技術來實現。生成的代碼有很高的運行效率。本庫可以不用編譯
            直接使用。

            Boost.Function的頭文件。
            function.hpp

            定義一個Boost.Function的對象(是一個返回值類型為int,第一個參數是std::string類型
            第二個參數是float類新)

            boost::function< int ( std::string, float ) > funptr;

            上面這個定義方式是一種容易理解的定義方式。但有些編譯器不支持,如果想更多的編譯器
            支持,則用下面這種定義方式

            boost::function2< int, std::string, float > funptr;

            注意模板中有3個類型,而function類卻是boost::function2。應為返回值類型不計算在參數
            類型中(原因很簡單,C++的編譯器不會根據返回類型不同來區分函數定義的不同)。

            int freefun( std::string str, float f )
            {
                std::cout << str << " : " << f << std::endl;
                return 0;
            }

            class CFun
            {
            public:
                int operator() ( std::string str, float f )
                {
                    std::cout << str << " : " << f << std::endl;
                    return 0; 
                }
            }

            上面定義了一個自由函數和一個函數對象。下面將把他們付給function對象。

            賦值為自由函數
            funptr = &freefun;

            賦值為函數對象
            CFun fun;
            funptr = fun;

            以上兩種情況的調用方法一致,如下
            funptr( "float =", 10.0 );

            Boost.Function對象要能指向類型原函數,其定義要如下

            class FreeClass
            {
            public:
                int out( std::string str, float f )
                {
                    std::cout << str << " : " << f << std::endl;
                    return 0; 
                }
            };

            boost::function< int ( FreeClass*, std::string, float ) > funptr;

            跨平臺的定義方法
            boost::function3< int, FreeClass*, std::string, float > funptr;

            賦值方法
            funptr = &FreeClass::out;

            調用方法
            FreeClass fc;

            funptr( &fc, "float =", 10.0 );


            posted on 2007-07-18 13:28 walkspeed 閱讀(10612) 評論(2)  編輯 收藏 引用 所屬分類: STL、Boost、范型編程C++語言

            FeedBack:
            # re: Boost.Function的基本使用
            2008-02-13 11:05 | stlf
            不錯, 文章寫得很清晰!  回復  更多評論
              
            # re: Boost.Function的基本使用
            2008-03-28 10:27 | Ason Jia
            寫的是不錯,不過內容太少了,要是再多一些,可以整理成一片初級指南  回復  更多評論
              

            <2012年12月>
            2526272829301
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            常用鏈接

            留言簿(4)

            隨筆分類(64)

            隨筆檔案(58)

            文章分類(3)

            文章檔案(3)

            相冊

            收藏夾(9)

            C++零碎

            好友

            搜索

            •  

            積分與排名

            • 積分 - 160843
            • 排名 - 163

            最新評論

            閱讀排行榜

            評論排行榜

            久久久国产精品亚洲一区| 99久久成人国产精品免费| 久久人妻少妇嫩草AV无码蜜桃| 久久精品国产精品亚洲艾草网美妙| 久久天天躁狠狠躁夜夜av浪潮| 久久久久久久波多野结衣高潮| 国产亚洲精品美女久久久| 久久免费大片| 狠狠色丁香婷综合久久| 国内精品伊人久久久影院| 久久青青草原精品影院| 久久久久久久97| 精品人妻伦一二三区久久| 久久久久AV综合网成人 | 国产69精品久久久久99| 亚洲精品无码久久久久AV麻豆| 99精品国产在热久久| 久久精品国产久精国产果冻传媒 | 色婷婷综合久久久中文字幕| 狠狠色综合网站久久久久久久| 蜜臀av性久久久久蜜臀aⅴ| 久久精品人妻一区二区三区| 国产精品久久久久影院色| 婷婷久久香蕉五月综合加勒比| 欧美久久亚洲精品| 久久精品国产欧美日韩| 伊人久久综在合线亚洲2019| 国产精品久久久久国产A级| 日本欧美久久久久免费播放网 | 国内精品综合久久久40p| 亚洲国产精品综合久久一线| 四虎影视久久久免费观看| 99久久国产综合精品五月天喷水 | 亚洲国产精品无码久久久久久曰 | 久久国产亚洲精品麻豆| 久久精品蜜芽亚洲国产AV| 午夜欧美精品久久久久久久| 伊人久久大香线蕉av一区| 亚洲av伊人久久综合密臀性色| 99精品国产99久久久久久97 | 91精品国产综合久久香蕉 |