我使用模板化引用通过函数类型引用来捕获函数,但是当我尝试通过 param() 调用时它崩溃了(使用 Apple LLVM 版本 9.0.0 (clang-900.0.38),x86_64-苹果-darwin17.2.0)
#include <iostream>
#include <typeinfo>
int doit(int a, int b) {
return a+b;
}
template <typename T>
void test(T & param) {
std::cout << typeid(T).name() << " ";
std::cout << typeid(param).name() << " ";
std::cout << param(3,5);
}
int main()
{
test(doit);
}
但是根据 Scott Meyers 的书“函数类型可以衰减为函数指针”:
void someFunc(int, double); // someFunc is a function; type is void(int, double)
template<typename T>
void f1(T param); // in f1, param passed by value
template<typename T>
void f2(T& param); // in f2, param passed by ref
f1(someFunc); // param deduced as ptr-to-func; type is void (*)(int, double)
f2(someFunc); // param deduced as ref-to-func; type is void (&)(int, double)
所以我希望参数是一个函数引用类型并由它调用。 怎么了?
更新:看起来这是一个 Clang 优化器错误! FIX:在调用参数之前评估参数的值 - 修复了这种情况!
std::cout << param << " - " << (*param)(3,5);
最佳答案
这似乎是一个 Clang 优化器错误! FIX:在调用参数之前评估参数的值 - 修复了这种情况!
std::cout << param << " - " << (*param)(3,5);
关于C++ 对函数的引用在调用中崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47363242/