class C {
public:
C() {}
};
template<typename T>
void func(T f) {}
int main() {
func(C);
}如何修正编译错误"2.cpp:9:15: error:预期的主-表达式之前的‘)’令牌函数(C);“?
将类作为参数传递似乎很荒谬,但我想像线程一样编译函数,因为“线程(C)”工作得很好:
#include <thread>
class C {
public:
C() {}
};
template<typename T>
void func(T f) {}
int main() {
std::thread(C);
}发布于 2017-06-12 07:13:34
不幸的是,one cannot take address of a constructor in C++。也就是说,您不能简单地将“指向构造函数的指针”作为函子使用(就像对空闲函数或成员函数所做的那样)。
实际上,您不能将类作为参数“传递”,因为C++核心没有反射,如果在运行时获得“类”,则不能对其执行任何操作。您只能作为模板参数“传递类”。
不过,您可以简单地使用lambda函数来调用相应的构造函数:
class C {
public:
C() {}
};
template<typename T>
void func(T f) {
auto c_instance = f();
}
int main() {
func([](){ return C(); });
}注意,您仍然没有在运行时传递任何返回类型的lambda [](){ return C(); }是已知的编译时,因此auto c_instance的类型也是已知的编译时。
但是,我认为,如果不需要将C的任何其他工厂传递给func,那么在func中简单地创建实例就更清楚了:
class C {
public:
C() {}
};
template<typename T>
void func() {
T c_instance;
}
int main() {
func<C>();
}关于std::thread(c);
std::thread(C);不是函数调用。std::thread是一种类型。因此,它声明了一个名为C的局部变量。使用
auto a = std::thread(C);应该会产生类似的编译器错误。
https://stackoverflow.com/questions/44491995
复制相似问题