Один из моих личных экспериментов для понимания некоторых функций C++ 0x: Я пытаюсь передать указатель на функцию шаблона для выполнения. В конце концов выполнение должно происходить в другом потоке. Но со всеми различными типами функций я не могу заставить шаблоны работать.Шаблоны, указатели функций и C++ 0x
#include <functional>
int foo(void) {return 2;}
class bar {
public:
int operator() (void) {return 4;};
int something(int a) {return a;};
};
template <class C>
int func(C&& c)
{
//typedef typename std::result_of< C() >::type result_type;
typedef typename std::conditional<
std::is_pointer<C>::value,
std::result_of< C() >::type,
std::conditional<
std::is_object<C>::value,
std::result_of< typename C::operator() >::type,
void>
>::type result_type;
result_type result = c();
return result;
}
int main(int argc, char* argv[])
{
// call with a function pointer
func(foo);
// call with a member function
bar b;
func(b);
// call with a bind expression
func(std::bind(&bar::something, b, 42));
// call with a lambda expression
func([](void)->int {return 12;});
return 0;
}
Шаблон result_of в одиночку, кажется, не сможет найти оператор() в классе бар и неуклюжим условный я создал не компилируется. Есть идеи? У меня возникнут дополнительные проблемы с функциями const?
Возможно, причина, по которой он не компилируется, заключается в том, что 'func' возвращает' int' вместо 'result_type' (который в этом примере является' int' во всех случаях, но может все еще вызвать проблему)? –
@ Крис: Нет, это не причина. – kennytm
@KennyTM - Я не думал, но все же думаю, что это проблема. –