c++ - C++03 中的函数返回类型推导

标签 c++ templates return-type c++03 type-deduction

标签提出了问题,但尽管如此,请考虑以下内容:

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);
}

在更一般的情况下(任意仿函数),没有编译器支持或类型的合作是不可能的。

关于c++ - C++03 中的函数返回类型推导,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26080471/

相关文章:

c - 如何用一个函数动态返回数字或字符串?

Perl:函数返回引用还是副本?

java - JNI 的另一个 java.lang.UnsatisfiedLinkError

c++ - 为三角矩阵计算优化 CUDA 内核的执行

c++ - 使用 boost 的 Glob 风格正则表达式模式匹配

c++ - 为什么 Sprite 不在 OpenGL 中渲染?

ruby-on-rails - 如何在 slim (rails) 中生成新的 View 文件?

c++ - 模板的部分模板特化

c++ - C++模板方法定义在类中不匹配

c++ - 覆盖具有不同返回类型的虚函数会引发私有(private)继承错误