• <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 - 18,  comments - 104,  trackbacks - 0
            關于boost::tuple的實現,請參見http://m.shnenglu.com/yindf/archive/2009/02/24/74801.html
            具體用法,請參見http://www.boost.org/doc/libs/1_38_0/libs/tuple/doc/tuple_users_guide.html

            關于表達式,在計算機中,最熟悉的就是前綴表達式,就像匯編一樣。所以,要先制定出來一套“匯編”,
            然后將c++表達式翻譯成“匯編”,保存起來,然后在需要的時候,把匯編展開成可執行的c++代碼,就OK了。

            這個說的太虛,來點實際的。
            表達式可以抽象地表達成 expression<class action, class argument>
            前面表示操作的類型,后面表示操作的對象。(注意,都是講類型,和對象沒關系)
            定義一組action,比如: add_action, mul_action ==
            然后對于argument,可能需要的argument數量不一樣多,所以用boost::tuple來保存argument,tuple最多可以保存10個type,基本夠用了。

            好了,那來個example吧。

            假設定義了
            class add_action {};
            class x_type {};
            class y_type {};

            x_type x;
            y_type y;
            那么 x + y, 對應的表達式就是 expression<add_action, tuple< x_type, y_type> >。 它是個類型,如果有一個這個類型的變量,那么x + y這個表達式的信息就可以保存起來了。這里有點抽象,慢慢理解。

            tuple里面當然可以保存expression,所以這個表達式可以嵌套起來,比如:
            expression<add_action, tuple< x_type, expression<mul_action, tuple<x_type, y_type> > >就對應 x + x * y 。

            所以如果
            expression<add_action, tuple< x_type, expression<mul_action, tuple<x_type, y_type> > > exp;

            exp是一個變量,它保存了x+x*y的這個表達式的信息,注意,是表達式的信息,和具體的變量沒有關系。

            看到這里是不是清楚了一點,有了這個表達式信息,這個表達式就可以在需要的地方被轉化成為可以執行的c++代碼。
            比如:

            template<class Arg>
            expression<add_action, Arg>
            {
               template <class _T>
               _T operator()(const _T& t1, const _T& t2)
               {
                  return t1 + t2;
               }
            };

            好了,現在想想x+x吧,他會被轉化成expression<add_action, tuple<x_type, x_type>;
            那么當我們定義expression<add_action, tuple<x_type, x_type> exp;以后呢,
            調用 exp(3.0, 4.0),就會調用上面那個模板函數的operator(),然后t1==3.0, t2==4.0, 返回的結果就是3.0+4.0=7.0了。
            注意紅色的地方,這就是把表達式信息轉化為可執行c++語句的關鍵。
            現在exp就表示兩個對象相加,任何對象都可以,只要能執行 operator+ ,都可以。
            那么 exp(3.0, exp(4.0, 5.0) ) 就表示 3.0+(4.0+5.0) 啦。

            當定義了足夠多的”匯編“表達以后,c++的表達式就可以自由的轉化成這種可以被保存起來的表達式。

            這里忽略了一個問題,就是我們只知道最終要轉化的目標,但是手段,或者說方法呢,就是說怎么通過 x+x 制造
            一個expression<add_action, tuple<x_type, x_type>類型出來,這就要靠模板演繹了。很復雜,
            下一篇再說吧。

            總結一下,主要內容是如何把表達式的信息保存起來,怎么把保存好的信息和c++的基本操作對應起來。
            posted on 2009-03-11 20:23 尹東斐 閱讀(1406) 評論(3)  編輯 收藏 引用

            FeedBack:
            # re: 深入探索 boost::lambda 系列(四)
            2009-03-17 09:07 | wulin
            頂一個  回復  更多評論
              
            # re: 深入探索 boost::lambda 系列(四)
            2009-03-19 08:36 | 蔡芳鈞
            我來頂啦~~  回復  更多評論
              
            # re: 深入探索 boost::lambda 系列(四)
            2009-03-19 18:39 | 尹東斐
            @蔡芳鈞
            @wulin

            歡迎來頂 : )  回復  更多評論
              
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            常用鏈接

            留言簿(4)

            隨筆檔案

            文章分類

            文章檔案

            相冊

            好友博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲中文字幕无码久久2020| 久久久亚洲精品蜜桃臀| 亚洲va国产va天堂va久久| 欧美熟妇另类久久久久久不卡| 狠狠色婷婷综合天天久久丁香| 2021国产精品久久精品| 伊人久久大香线蕉综合5g| 亚洲AV伊人久久青青草原| 五月丁香综合激情六月久久| 国产精品久久网| 久久精品日日躁夜夜躁欧美| 久久这里只有精品首页| 精品伊人久久久| 国产综合免费精品久久久| 久久久久亚洲av无码专区导航| 色综合色天天久久婷婷基地| 狠狠色丁香婷婷久久综合| 精品九九久久国内精品| 老男人久久青草av高清| AV无码久久久久不卡网站下载| 中文成人无码精品久久久不卡| 午夜人妻久久久久久久久| 久久久网中文字幕| 日韩人妻无码一区二区三区久久| 久久精品国产精品亚洲| 久久久精品人妻一区二区三区四| 国产精品99久久精品爆乳| 亚洲中文字幕无码一久久区| 日韩va亚洲va欧美va久久| 久久青草国产精品一区| 高清免费久久午夜精品| 热久久最新网站获取| 国产午夜精品久久久久九九| 精品精品国产自在久久高清| 丁香狠狠色婷婷久久综合| 久久狠狠色狠狠色综合| 99热成人精品热久久669| 97久久天天综合色天天综合色hd| 精品久久久久久无码专区| 亚洲国产另类久久久精品黑人| 久久大香萑太香蕉av|