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

            大龍的博客

            常用鏈接

            統計

            最新評論

            boost::bind介紹

            boost::bind介紹
            bind的中文翻譯是"綁定",它的作用就是把參數與象函數一樣的"東西"進行"綁定",然后象
            函數一樣運行.那象函數一樣的"東西"到底是什么東西呢?
            象函數一樣的"東西"還挺多的.
            int f1();
            free function,這當然是一種.
            int C::method();
            某個class的method,當然也是一種.
            typedef int (*pfunc)();
            pfunc = f1;
            函數指針,也是一種.
            class C
            {
            public:
            void operator()();
            };
            C obj;
            obj(); //這是什么?看上去象函數調用.
            //它等于 obj.()() --- 如此怪異的東西
            //第一個()是函數名稱,第二個()才是函數調用符
            上面的class C有個標準名稱,functor.自然它也屬于象函數一樣的"東西".
            大概就這么點了吧,其他的反正現在是想不起來了,或許boost::function實現的"委托"也算一種
            (不敢肯定,還沒研究).
            下面看看bind是怎樣把參數依次與各個象函數一樣的"東西""綁定"的.
            1. bind free function
            int add(int x, int y)
            {
            return x + y;
            }
            add(1, 2) <===> boost::bind(add, 1, 2)
            int add1(int x)
            { <===> boost::bind(add, _1, 1)(x);
            return add(x, 1); 其中 _1 是placehold(占位符),會被x所取代
            }
            add(x, y) <===> boost::bind(add, _1, _2)(x, y);
            <===> boost::bind(add, _2, _1)(y, x);
            add(x, x) <===> boost::bind(add, _1, _1)(x, y)
            <===> boost::bind(add, _2, _2)(y, x)
            C Add(const C &objX, cinst C &objY)
            <===> boost::bind(Add, boost::cref(_1), boost::cref(_2))(objX, objY)
            由于是非buildin type, 所以通過reference可能更有效率.默認情況下boost::bind的參數都是copy一份,不是很
            有效率.
            2. bind functor
            struct F
            {
            int operator()(int a, int b) { return a - b; }
            bool operator()(long a, long b) { return a == b; }
            };
            F f;
            int x = 104;
            bind<int>(f, _1, _1)(x); // f(x, x), i.e. zero
            bind<int>(F(), _1, _1)(x); //F()是匿名object
            3. bind class method
            struct X
            {
            bool f(int a);
            };
            X x;
            shared_ptr<X> p(new X);
            int i = 5;
            bind(&X::f, boost::ref(x), _1)(i); //x.f(i)
            bind(&X::f, x, _1)(i); //x_copy = x, x_copy.f(i), 效率沒有上一行代碼高
            bind(&X::f, &x, _1)(i); //(&x)->f(i),索性傳指針
            bind(&X::f, p, _1)(i); //p是smart pointer object,所以也有copy動作
            //p_copy = p, p_copy->f(i)
            bind(&X::f, boost::ref(p), _1)(i); //比上面一行,高效一點
            4. Misc.
            add(add(1, 2), add(3, 4) <===> boost::bind(add, boost::bind(add, 1, 2), boost::bind(add, 3, 4))
            boost::bind支持嵌套
            bind的返回值呢?

            posted on 2007-01-08 15:40 大龍 閱讀(10409) 評論(0)  編輯 收藏 引用

            99久久婷婷免费国产综合精品| 久久99精品久久久久久秒播 | 久久99精品久久久久久齐齐| 久久精品无码专区免费| 欧美激情精品久久久久久久| 久久精品免费全国观看国产| 91精品国产乱码久久久久久| 国产亚洲精午夜久久久久久| 伊人久久大香线蕉综合热线| 久久国产精品77777| 亚洲欧美一区二区三区久久| 久久久久亚洲Av无码专| 欧美精品福利视频一区二区三区久久久精品 | 国产巨作麻豆欧美亚洲综合久久| 日韩va亚洲va欧美va久久| 久久91精品国产91久久户| 久久精品视频一| 久久免费视频6| 99久久亚洲综合精品成人| 久久夜色精品国产噜噜噜亚洲AV| 久久伊人中文无码| 国内精品久久久久久久亚洲| 国产成人精品免费久久久久| 亚洲精品无码久久久久sm| 久久AAAA片一区二区| 人人狠狠综合久久亚洲婷婷| 久久国产精品成人影院| A级毛片无码久久精品免费| 午夜精品久久久内射近拍高清| 一本一道久久精品综合| 久久精品成人免费看| 成人妇女免费播放久久久| 人妻无码久久一区二区三区免费| 亚洲午夜福利精品久久| 久久久久99精品成人片三人毛片 | 久久国产色AV免费观看| 伊人久久大香线蕉av不变影院| 亚洲国产精品成人AV无码久久综合影院| 91久久精品电影| 久久久久免费视频| 久久亚洲国产成人影院|