• <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 尹東斐 閱讀(1396) 評論(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

            歡迎來頂 : )  回復  更多評論
              
            <2009年3月>
            22232425262728
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(4)

            隨筆檔案

            文章分類

            文章檔案

            相冊

            好友博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲国产婷婷香蕉久久久久久| 狠狠色丁香久久婷婷综合蜜芽五月 | 久久久精品久久久久久| 久久精品视频网| 东京热TOKYO综合久久精品| 色综合久久久久综合体桃花网| 精品综合久久久久久98| 久久久亚洲裙底偷窥综合| 一个色综合久久| 久久国语露脸国产精品电影| 久久久久久免费视频| 思思久久99热免费精品6| 伊人久久亚洲综合影院| 亚洲欧洲中文日韩久久AV乱码| 亚洲午夜无码AV毛片久久| 久久精品一区二区三区AV| 久久精品久久久久观看99水蜜桃| 中文无码久久精品| 狠狠色丁香婷婷综合久久来| 老司机国内精品久久久久| 久久亚洲电影| 久久精品aⅴ无码中文字字幕不卡| 久久精品国产亚洲av麻豆色欲 | 日韩人妻无码精品久久免费一| 国产精品久久久久a影院| 久久夜色精品国产噜噜麻豆| 久久本道伊人久久| 日韩一区二区三区视频久久| 波多野结衣久久| 99精品久久精品| 合区精品久久久中文字幕一区| 国产免费久久精品99re丫y| 久久99国产综合精品免费| 狠狠色伊人久久精品综合网 | 久久久亚洲欧洲日产国码二区| 久久99国产精品久久久| 亚洲一级Av无码毛片久久精品| 91精品国产高清91久久久久久| 久久天天躁狠狠躁夜夜不卡| 久久人人爽人人爽人人片av高请| 色综合久久综精品|