功能返回类型扣除在C 03中
作者:互联网
标签会提出问题,但考虑以下因素:
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中推断出函数返回类型?
我正在寻找不需要手动指定返回类型的方法,也不需要对其他参数进行侵入式更改.如果这是不可能的,那么我只是在寻找一个权威声明来验证这一点.
解决方法:
如果仅限于函数指针,可以使用部分特化,例如
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);
}
在更一般的情况下(任意仿函数),没有编译器支持或类型的合作是不可能的.
标签:type-deduction,c,templates,return-type,c03 来源: https://codeday.me/bug/20190830/1768270.html