boost :: bind member function — частичная цепочка приложения

Я пытаюсь связать вместе карри функции, используя boost :: bind, и получаю ошибки компилятора, которые я не могу устранить. Простейший пример, который я могу привести, который не компилируется:

#include <iostream>
#include <boost/bind.hpp>

class A
{
public:
template <typename F>
void g(F fn, char c)
{
fn(c);
}

void h(char c)
{
std::cout << c << std::endl;
}

template <typename F>
void f(F fn, char c)
{
boost::bind(&A::g<F>, this, fn, ::_1)(c);
}
};

int main(int argc, char** argv)
{
char c = 'a';
A a;
a.f(boost::bind(&A::h, &a, ::_1), c);
}

не удается с этой ошибкой:

In file included from /usr/include/boost/bind.hpp:22,
from test8.cpp:2:
/usr/include/boost/bind/bind.hpp: In member function ‘void boost::_bi::list3<A1, A2, A3>::operator()(boost::_bi::type<void>, F&, A&, int) [with F = boost::_mfi::mf2<void, A, boost::_bi::bind_t<void, boost::_mfi::mf1<void, A, char>, boost::_bi::list2<boost::_bi::value<A*>, boost::arg<1> > >, char>, A = boost::_bi::list1<char&>, A1 = boost::_bi::value<A*>, A2 = boost::_bi::bind_t<void, boost::_mfi::mf1<void, A, char>, boost::_bi::list2<boost::_bi::value<A*>, boost::arg<1> > >, A3 = boost::arg<1>]’:
/usr/include/boost/bind/bind_template.hpp:32:   instantiated from ‘typename boost::_bi::result_traits<R, F>::type boost::_bi::bind_t<R, F, L>::operator()(A1&) [with A1 = char, R = void, F = boost::_mfi::mf2<void, A, boost::_bi::bind_t<void, boost::_mfi::mf1<void, A, char>, boost::_bi::list2<boost::_bi::value<A*>, boost::arg<1> > >, char>, L = boost::_bi::list3<boost::_bi::value<A*>, boost::_bi::bind_t<void, boost::_mfi::mf1<void, A, char>, boost::_bi::list2<boost::_bi::value<A*>, boost::arg<1> > >, boost::arg<1> >]’
test8.cpp:21:   instantiated from ‘void A::f(F, char) [with F = boost::_bi::bind_t<void, boost::_mfi::mf1<void, A, char>, boost::_bi::list2<boost::_bi::value<A*>, boost::arg<1> > >]’
test8.cpp:29:   instantiated from here
/usr/include/boost/bind/bind.hpp:385: error: invalid use of void expression

Это использует

$ g++ --version
g++ (Ubuntu 4.4.3-4ubuntu5.1) 4.4.3

3

Решение

Вам нужно использовать boost::protect() в таких случаях, когда вы передаете выражение связывания другому вызову связывания, но не хотите, чтобы вложенное выражение вызывалось во время оценки аргументов внешней связанной функции, а скорее хотите, чтобы вложенное выражение связывания передавалось как есть как аргумент для внешней связанной функции.
Вот это будет:

boost::bind(&A::g<F>, this, boost::protect(fn), ::_1)(c);
6

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]