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

            上次說到在假設(shè)類型int下,成功的實(shí)現(xiàn)了一個(gè)“lambda”,這次,當(dāng)然不能還在int的假設(shè)下了。我們的武器就是模板,說起來模板,話就長了。
            這里略過,講重點(diǎn)。

            這是上次最后的代碼,為了方便描述,再貼一份。

             1 struct op
             2 {
             3     op(int i)
             4         : _i(i)
             5     {}
             6 
             7     int _i;
             8 
             9     int operator()(int& i)
            10     {
            11         i = _i;
            12     }
            13 };
            14 
            15 struct place_holder
            16 {
            17     op operator=(int i)
            18     {
            19         return op(i)
            20     }
            21 };
            22 
            23 place_holder _1;
            24 
            25 for_each(v.begin(), v.end(), _1 = 3);


            要去掉對int的依賴,先仔細(xì)想想對int的依賴都在哪里?說明白點(diǎn)就是整個(gè)程序,哪里都有int?
            1.  op的構(gòu)造函數(shù)參數(shù)是int
            2.  op里面的成員變量 _i的類型是int
            3.  op的operator() 的返回值和參數(shù)都有int
            4.  place_holder的operator=的參數(shù)是int

            當(dāng)然 vector<int> 也有int,但這個(gè)不算 :)

            總的來說,int和 一個(gè)變量 int op::_i, 三個(gè)函數(shù) op::op(int i), op::operaator(int& i) 和 place_holder::operator=(int) 有關(guān)系,這一點(diǎn)很重要,類和函數(shù)在泛型中的作用不一樣,
            看看 http://m.shnenglu.com/yindf/archive/2009/02/20/74397.html 中說的類模板和函數(shù)模板的區(qū)別吧。

            再細(xì)分一點(diǎn),和 _1 有關(guān)的int就只有op::operator()一個(gè),其他都和 _1 沒關(guān)系。
            剩下的都和 3 有關(guān)系,想想 3 的傳遞路徑, 從 place_holder::operator = 到 op::op(int i), 再到 op::_i。

            也就是說op::operator()要一個(gè)獨(dú)立的模板參數(shù)。
            想想看,其實(shí)op::op(int i) 和 op::_i 是一個(gè)東西,構(gòu)造函數(shù)就是為了初始化這個(gè)變量。所以這里選擇泛化整個(gè)op,就是說構(gòu)造函數(shù)的參數(shù)和變量是同一個(gè)類型。
            對于place_holder::operator =, 是要泛化整個(gè)place_holder呢,還是只泛化place_holder::operator=呢,當(dāng)然泛化函數(shù),因?yàn)轭惒粫M(jìn)行類型推導(dǎo)。
            意思是如果泛化類的話,你就要有為無數(shù)類型特化過的place_holder,這里很難理解,不理解的話,繼續(xù)看下去吧。

            現(xiàn)在就開始實(shí)做吧。

             1 template <typename _U>
             2 struct op
             3 {
             4     op(_U i)
             5         : _i(i)
             6     {}
             7 
             8     _U _i;
             9 
            10     template<typename _T>
            11     _T& operator()(_T& i)
            12     {
            13         i = _i;
            14     }
            15 };
            16 
            17 struct place_holder
            18 {
            19     template <typename _T>
            20     op<_T> operator=(_T i)
            21     {
            22         return op<_T>(i)
            23     }
            24 };
            25 
            26 place_holder _1;
            27 
            28 for_each(v.begin(), v.end(), _1 = 3);


            好了,泛化完成。難道就這么簡單?事實(shí)就是這么簡單。
            來分析一下模板推導(dǎo)的過程吧,  _1 = 3 調(diào)用,從下面這個(gè)函數(shù)開始,

            1 template <typename _T>
            2 op<_T> place_holder::operator=(_T i);


            那么這個(gè)_T 被推導(dǎo)為 int, 然后返回一個(gè) op<int>, 然后 op<int> 里面就有一個(gè) int op<int>::_i;

            于是,在for_each里面,相當(dāng)于有這么一句:

            1 op<int> p;
            2 p(*iter);

            op的模板參數(shù)被推定義為int了(不是推導(dǎo)的,類模板不會推導(dǎo))。

            所以手法是先靠函數(shù)推導(dǎo)模板參數(shù),再靠類保存類型信息。

            于是,下面的函數(shù)模板

            1 template<typename _T>
            2 _T& op<int>::operator()(_T& i)
            3 {
            4     i = _i;
            5 }


            的模板參數(shù) _T 就被推導(dǎo)成 *iter 的類型了,也就是容器的 value_type 了。

            好了,到現(xiàn)在,一個(gè)賦值的lambda就做好了,它還能這么用:

            1 double x;
            2 (_1 = 5)(x);

            就給x賦值5了,神奇吧。
            因?yàn)?nbsp; (_1 = 5)返回的是個(gè)lambda表達(dá)式,也就是個(gè)仿函數(shù),:)

            現(xiàn)在才看到lambda核心的一小部分,已經(jīng)讓人感覺眩暈了。
            看看現(xiàn)在還存在的問題,只實(shí)現(xiàn)了一個(gè)賦值操作,其他的呢? 下篇繼續(xù)。。。

            posted on 2009-02-20 19:21 尹東斐 閱讀(1022) 評論(5)  編輯 收藏 引用 所屬分類: 深入探索 boost::lambda 系列

            FeedBack:
            # re: 深入探索 boost::lambda 系列(二)
            2009-02-20 21:51 | 發(fā)生地方
            貌似比較復(fù)雜啊  回復(fù)  更多評論
              
            # re: 深入探索 boost::lambda 系列(二)[未登錄]
            2009-02-21 08:27 | cppexplore
            頂博主
            多發(fā)寫相關(guān)的東西啊
            坐下來慢慢看  回復(fù)  更多評論
              
            # re: 深入探索 boost::lambda 系列(二)
            2009-02-23 15:23 | luke
            博主研究c++想必有多年的功力了吧,支持一下?。?!  回復(fù)  更多評論
              
            # re: 深入探索 boost::lambda 系列(二)
            2010-10-14 15:55 | 匿名
            Great!崇拜一下!  回復(fù)  更多評論
              
            # re: 深入探索 boost::lambda 系列(二)
            2012-11-05 17:04 | 匿名
            為什么op類的模板參數(shù)和operator()的模板參數(shù)需要兩個(gè)呢?為什么op::operator()也需要十個(gè)模板函數(shù)呢?  回復(fù)  更多評論
              
            <2009年3月>
            22232425262728
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(4)

            隨筆檔案

            文章分類

            文章檔案

            相冊

            好友博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久青青草原精品国产| 亚洲AV无码久久| 丰满少妇人妻久久久久久4| 久久综合亚洲色HEZYO国产| 久久夜色精品国产网站| 久久ZYZ资源站无码中文动漫| 久久精品国产久精国产思思| 久久99精品国产99久久6| 亚洲国产成人久久精品99| 亚洲欧美精品伊人久久| 久久久一本精品99久久精品66 | 青青青国产精品国产精品久久久久 | 久久精品亚洲精品国产欧美| 久久免费精品视频| 久久综合亚洲色HEZYO国产| 欧美噜噜久久久XXX| 亚洲国产精品综合久久一线| 久久av无码专区亚洲av桃花岛| 久久久久亚洲AV成人片| 久久久WWW免费人成精品| 国产成年无码久久久久毛片| 久久精品国产2020| 性高朝久久久久久久久久| 久久er国产精品免费观看8| 久久综合综合久久综合| 久久人人爽人人爽人人片AV麻豆| 69久久夜色精品国产69 | 色综合久久88色综合天天 | 久久亚洲高清观看| 97久久久精品综合88久久| 亚洲精品国精品久久99热一| 久久99热这里只频精品6| 国产成人精品综合久久久| 日产精品久久久久久久| 天天影视色香欲综合久久| 久久久久九九精品影院| 色综合久久综精品| 国内精品欧美久久精品| 久久99精品久久久久久不卡 | 久久精品中文騷妇女内射| 久久精品国产亚洲av影院|