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

            FireEmissary

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              14 隨筆 :: 0 文章 :: 20 評(píng)論 :: 0 Trackbacks
            老實(shí)說,我不知道C++11有了lambda,怎么還會(huì)要引入bind.
            bind這玩意,嵌套兩層就得出汗,嵌套三四層絕對(duì)要人提心吊膽驗(yàn)證n久.還有個(gè)自以為是的功能:如果綁定的參數(shù)是bind對(duì)象,它就自作聰明去調(diào)用.問題是,有時(shí)候你確實(shí)要個(gè)可調(diào)用對(duì)象而不是可調(diào)用對(duì)象的調(diào)用返回值,你要不就得用ref包裹bind,要不就得格外寫個(gè)可調(diào)用對(duì)象使得std::is_bind_expression<T>::value == true判斷不成立.這格外寫個(gè)可調(diào)用對(duì)象的簡(jiǎn)單方法是什么:就是用lambda.....
            有人會(huì)說:bind能做的事lambda不能做,比如bind可以綁定一個(gè)可調(diào)用對(duì)象,這個(gè)可調(diào)用對(duì)象有多個(gè)可調(diào)用operator call或者template call.如下:

             struct foo
            {
            typedef 
            void result_type;

            template 
            < typename A, typename B >
            void operator()(A a, B b)
            {
            std::cout 
            << "operator()(A a, B b)"<<std::endl;
            }
            void operator()(int a,int b)
            {
            std::cout 
            << "operator()(int a,int b)"<<std::endl;
            }
            int operator()(int a,char b)
            {
            std::cout 
            << "operator()(int a,char b)"<<std::endl;
            return 1;
            }
            };
            int main()
            {
            using namespace std::placeholders;
            auto f 
            = std::bind(foo(), _1,_2);
            f(
            "test"1.2f);
            f(
            2,3);
            std::cout
            <<"get:"<<f(2,'3');
            return 0;
            }

            沒錯(cuò),lambda必須指定函數(shù)參數(shù)類型,表面上看也許沒那么"可變".然而你要考慮實(shí)際應(yīng)用場(chǎng)景.bind一個(gè)對(duì)象后怎么用它呢?一般使用場(chǎng)景是保存起來以備使用.而目前class 成員顯然不是一個(gè)auto可以指定,它得是具體的類型,比如std::function<void(int ,float)>.如果把上面代碼里的 f保存在一個(gè)std::function<void(int ,float)>類型里面,那么當(dāng)后來調(diào)用它傳入兩個(gè)整型時(shí)會(huì)調(diào)用哪個(gè)函數(shù)?不是operator()(int a,int b)  而是operator()(A a, B b)!所以除非你bind一個(gè)對(duì)象后立馬在當(dāng)前函數(shù)里使用(多此一舉),否則bind的參數(shù)靈活性基本發(fā)揮不出來.
            這就給出了兩個(gè)易出錯(cuò)場(chǎng)景:
            一個(gè)是傳給bind的參數(shù)是可調(diào)用對(duì)象是,表現(xiàn)不一樣(可調(diào)用對(duì)象是另一個(gè)bind時(shí),會(huì)被調(diào)用,其它則當(dāng)成普通對(duì)象)
            另一個(gè)是對(duì)于bind一個(gè)類,類里面有多個(gè)可調(diào)用函數(shù)時(shí),出現(xiàn)你以為調(diào)用operator()(int a,int b)  而實(shí)際上是operator()(A a, B b).反之lambda的直觀使得它更容易找出問題.
            再加上bind多層嵌套使用帶來的可讀性問題(這其實(shí)也是易出錯(cuò)場(chǎng)景),我的看法是:學(xué)好lambda,遠(yuǎn)離bind.
            posted on 2013-03-10 09:11 FireEmissary 閱讀(7960) 評(píng)論(11)  編輯 收藏 引用

            評(píng)論

            # re: 使用lambda,遠(yuǎn)離bind 2013-03-11 00:57 YzL
            auto是C++11才有的東西,而bind()已經(jīng)存在并在舊的C++標(biāo)準(zhǔn)上實(shí)現(xiàn)了很久了,比如boost::bind(),并不是只有auto才能保存/推導(dǎo)bind()對(duì)象,模版也可以,看下面的代碼:
            template<typename CallType>
            void Func(CallType call)
            {
            call();
            }
            這種情況bind()能生成/適配出實(shí)際上具有N個(gè)參數(shù)的call(),lambda則永遠(yuǎn)只能沒參數(shù),雖然lambda可以訪問外部變量來模擬多參數(shù),但是當(dāng)Func()需要多次在不同的作用域調(diào)用、或者call()本身是第三方庫(kù)時(shí),bind()就要方便得多  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind[未登錄] 2013-03-11 03:43 lost
            求排版  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind 2013-03-12 15:26 w
            還是傳統(tǒng)的寫法簡(jiǎn)單靠譜, 非得搞這些所謂的亂七八糟的新特性,c++真是走火入魔了  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind[未登錄] 2013-03-14 00:05 Jcily
            我覺得bind和lambda這兩個(gè)面向的問題針對(duì)性不同。

            兩者并沒有可比性。

            bind體現(xiàn)在幫助我們簡(jiǎn)潔快速的打包一個(gè)函數(shù)對(duì)象的便捷性,而不用像“仿函數(shù)”去手動(dòng)用操作符重載的方法寫一個(gè)class或者struct。

            lambda重點(diǎn)是當(dāng)你需要一個(gè)閉包。比如你懶得去定義一個(gè)只會(huì)被這里調(diào)用一次的回調(diào)函數(shù),更不想另外手寫定義一些變量幫它保存當(dāng)時(shí)的局部環(huán)境狀態(tài)。  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind 2013-03-14 09:50 xinqing
            lambda可以有參數(shù),也可以有返回值  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind[未登錄] 2013-03-14 13:25
            @Jcily
            頂  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind 2013-03-15 16:10 bill gates
            bind有個(gè)東西叫protect,就是用來取消函數(shù)組合(bind的默認(rèn)行為)。C++最大的問題是用底層概念實(shí)現(xiàn)了上層抽象,這樣在調(diào)試程序的時(shí)候,由于底層實(shí)現(xiàn)不是自己寫的,導(dǎo)致出問題幾乎無法調(diào)試,除非你去看那些實(shí)現(xiàn)的源代碼。調(diào)試過幾次bind,相當(dāng)痛苦。  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind 2013-03-15 16:11 liyou
            @Jcily
            有見地。  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind 2013-03-15 22:54 wingfire
            “除非你bind一個(gè)對(duì)象后立馬在當(dāng)前函數(shù)里使用(多此一舉),否則bind的參數(shù)靈活性基本發(fā)揮不出來.”
            這個(gè)何出此言?不考慮和模板的合作嗎?bind的結(jié)果可以傳給模板函數(shù)啊,不一定要返回。就算返回,在類型自動(dòng)推導(dǎo)時(shí)也是有用的。  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind 2013-03-15 22:55 wingfire
            lambda不支持模板是C++11的一大敗筆,事實(shí)就是如此。  回復(fù)  更多評(píng)論
              

            # re: 使用lambda,遠(yuǎn)離bind 2013-03-16 13:35 FireEmissary
            @wingfire
            lambda不支持模板是遺憾而不是敗筆,因?yàn)樗⒎菍聿豢筛倪M(jìn).
            至于和模板的合作,從最新的書籍來看也是建議用lambda.誠(chéng)如<<The C++ Standard Library>>Second Edition所說(10.2.4):


            std::find_if (coll.begin(), coll.end(),
            std::bind(std::logical_not<bool>(),
            std::bind(std::modulus<int>(),
            std::placeholder::_1,
            2)));

            Being able to use a lambda is really an improvement here:

            std::find_if (coll.begin(), coll.end(),
            [](int elem){
            return elem%2==0;
            });
              回復(fù)  更多評(píng)論
              


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            一本大道久久东京热无码AV | 久久精品无码av| 久久亚洲AV成人无码国产| 伊人久久大香线蕉影院95| 欧美精品久久久久久久自慰| 狠狠色婷婷久久一区二区 | 亚洲人成无码网站久久99热国产| 精品久久久久久久中文字幕 | 伊人久久综合无码成人网| 伊人久久大香线蕉综合网站| 久久久久久久久66精品片| 色综合久久夜色精品国产| 亚洲va国产va天堂va久久| 国产精品免费看久久久| 久久综合久久鬼色| 伊人色综合久久天天人守人婷| 99精品久久久久久久婷婷| 无码专区久久综合久中文字幕| 久久精品黄AA片一区二区三区| 伊人久久综在合线亚洲2019 | 久久无码国产专区精品| 久久久久久久亚洲Av无码| 韩国无遮挡三级久久| 久久亚洲高清综合| 亚洲精品无码久久千人斩| 久久精品国产福利国产秒| 久久99精品久久久久久不卡| 亚洲AV伊人久久青青草原| 欧美熟妇另类久久久久久不卡| 91久久成人免费| 青青草原综合久久大伊人| 色综合久久久久网| 久久精品国产亚洲av麻豆蜜芽| 国内精品久久久久久野外| 久久只有这精品99| 97超级碰碰碰碰久久久久| 久久精品国产清自在天天线| 99久久99久久精品国产片| 久久精品蜜芽亚洲国产AV| 亚洲欧洲精品成人久久曰影片| 久久99精品国产一区二区三区|