2012-10-25 8 views
8

次のコードスニペットを参照してください。オーバーロードされた機能foobarにはstd::bindを使用します。引数のないメソッドだけを呼び出します。std :: bindとoverloaded関数

auto a2 = std::bind(static_cast<void(Client::*)(int)>(&Client::foobar), cl, 
        std::placeholders::_1); 
a2(5); 

あなたはまた、(値ではなく、参照することによって結合し、これがあることに注意してくださいcl)のラムダ・キャプチャーとの結合を行うことができます:

#include <functional> 
#include <iostream> 
class Client 
{ 
    public : 
    void foobar(){std::cout << "no argument" << std::endl;} 
    void foobar(int){std::cout << "int argument" << std::endl;} 
    void foobar(double){std::cout << "double argument" << std::endl;} 
}; 

int main() 
{ 
    Client cl; 
    //! This works 
    auto a1 = std::bind(static_cast<void(Client::*)(void)>(&Client::foobar),cl); 
    a1(); 
    //! This does not 
    auto a2= [&](int) 
    { 
     std::bind(static_cast<void(Client::*)(int)>(&Client::foobar),cl); 
    }; 
    a2(5); 
    return 0; 
} 
+0

あなたのラムダに 'return'がありません。 – ildjarn

答えて

11

あなたが結合していない引数にplaceholdersを使用する必要が

auto a2 = [&](int i) { cl.foobar(i); }; 
+0

ありがとうecatmur、それは動作します。 – Atul

+0

そして値渡しは '[&、i]'または '[=、&cl]'で行うことができます。 – Xeo

関連する問題