标签会提出问题,但请考虑以下因素:
template<typename F, typename A, typename R>
R call(F function, A arg) {
return function(arg);
}
int foo(char) {
return 5;
}
int main() {
call(foo, 'a');
}
如果删除了参数R并且手动插入int作为返回类型,编译器会愉快地编译它。如图所示,编译器无法知道如何制作R。
如何在C ++ 03中推断出函数返回类型?
我正在寻找不需要手动指定返回类型的方法,也不需要对其他参数进行侵入式更改。如果这是不可能的,那么我只是在寻找一份权威声明来证明这一点。
答案 0 :(得分:5)
如果仅限于函数指针,可以使用部分特化,如
template<class T> struct func_ptr_result {};
template<class R>
struct func_ptr_result<R (*)()> {
typedef R type;
};
template<class R, class Arg1>
struct func_ptr_result<R (*)(Arg1)> {
typedef R type;
};
// etc for > 1 arguments
template<typename F, typename A>
typename func_ptr_result<F>::type call(F function, A arg) {
return function(arg);
}
在更一般的情况下(任意仿函数),如果没有编译器支持或类型的合作,就不可能。