Я пытался следовать объяснению Бьярна Страуступса функции
] шаблон. Я специально играл с взаимозаменяемостью указателей c-функций , функторы , лямбды и указатели на функции-члены
Учитывая определения:
struct IntDiv { // functor
float operator()(int x, int y) const
{ return ((float)x)/y; }
};
// function pointer
float cfunc(int x, int y) { return (float)x+y; }
struct X { // member function
float mem(int x, int y) const { return ...; }
};
using namespace placeholders; // _1, _2, ...
Я хочу назначить функцию
все возможное:
int main() {
// declare function object
function f;
//== functor ==
f = IntDiv{}; // OK
//== lambda ==
f = [](int x,int y)->float { return ((float)y)/x; }; // OK
//== funcp ==
f = &cfunc; // OK
// derived from bjarnes faq:
function g; // extra argument 'this'
g = &X::mem; // set to memer function
X x{}; // member function calls need a 'this'
cout << g(&x, 7,8); // x->mem(7,8), OK.
//== member function ==
f = bind(g, &x,_2,_3); // ERROR
}
И последняя строка дает типичную нечитаемую ошибку-шаблон-компилятора. вздох .
Я хочу связать f
с существующей функцией-членом x
экземпляров, чтобы только подпись float (int, int) Осталось
.
Какой должна быть строка вместо
f = bind(g, &x,_2,_3);
... или где еще ошибка?
Справочная информация:
Вот пример Бьярнеса для использования bind
и функция
с функцией-членом:
struct X {
int foo(int);
};
function f;
f = &X::foo; // pointer to member
X x;
int v = f(&x, 5); // call X::foo() for x with 5
function ff = std::bind(f,&x,_1)
Я думал, что bind
используется следующим образом: неназначенные места получают заполнители
, остальное заполняется в привязке
. Должен ли _1
орех получить это
тогда`? И поэтому последняя строка:
function ff = std::bind(f,&x,_2)
По предложению Ховардса ниже я попробовал :-)