См. Следующий фрагмент кода. Я хочу использовать std::bind для перегруженной функции foobar. Он вызывает только метод без аргументов.

#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;
}
15
Atul 25 Окт 2012 в 12:37
1
Вам не хватает return в лямбде.
 – 
ildjarn
26 Окт 2012 в 00:22

1 ответ

Лучший ответ

Вам необходимо использовать placeholders для несвязанных аргументов:

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

Вы также можете выполнить привязку с помощью лямбда-захвата (обратите внимание, что это связывает cl по ссылке, а не по значению):

auto a2 = [&](int i) { cl.foobar(i); };
18
ecatmur 25 Окт 2012 в 12:46
А захват по значению можно выполнить с помощью [&,i] или [=,&cl].
 – 
Xeo
26 Окт 2012 в 06:50