参考以下代码
#include <iostream>
using std::cout;
using std::endl;
#include <vector>
using std::vector;
void function() {
cout << "Hello World" << endl;
}
int main() {
vector<void (*) ()> functions;
functions.push_back(function); // (1) no error
functions.push_back(&function); // (2) no error
for (const auto& func : functions) {
func();
}
// vector<decltype(function)> vec; // (3) error
return 0;
}
当我取消注释(3)时似乎有一个错误,我只是想了解这背后的原因。当我将函数作为参数传递给模板化函数时,它是否将类型解析为函数指针?编译器将所有函数类型推断为函数指针是有意义的,但为什么decltype()不能解析为函数指针?
答案 0 :(得分:7)
decltype(function)
是void()
- 一个功能
你需要的是一个函数的衰变版本 - void(*)()
:
std::decay<decltype(function)>::type
std::vector < std::decay<decltype(function)>::type > myPtrFunctionVec;
PS。
如果您正在使用VC ++(visual stdio),则可以通过打印decltype
轻松查看从typeid(decltype(XXX)).name()
推导出的类型。与其他编译器不同,VC ++给出了未修饰的类型名称。非常方便的元编程调试。
<强> 编辑: 强>
正如@Daniel Jour评论的那样,解决方案decltype(&function)
也可以工作,因为构造&f
给出了指向f
的指针,这就是你需要的