为什么这个小例子:
class A {
public:
virtual void run() = 0;
};
class B : public A {
public:
void run() override {
std::cout << "Running...\n";
}
};
int main() {
std::unique_ptr<A> a = std::make_unique<A>(new B());
}给我这个错误消息:
error: invalid new-expression of abstract class type 'A'
{ return unique_ptr<_Tp>(new _Tp(std::forward<_Args>(__args)...)); }
because the following virtual functions are pure within 'A':
class A {
'virtual void A::run()'
virtual void run() = 0;这是因为unique_ptr不能接受抽象类作为参数吗?
发布于 2019-04-01 00:51:41
为什么这个小例子:.给出以下错误消息:
invalid new-expression of abstract这是因为unique_ptr不能接受抽象类作为参数吗?
不,不是。std::unique_ptr可以把抽象类作为参数。
这是因为您正在尝试创建一个A实例。这是不可能的,因为A是抽象的。
您可能打算创建一个B实例,并让std::unique_ptr<A>获取该指针的所有权:
std::unique_ptr<A> a = std::make_unique<B>();但是,请注意,不能让这个指针超出作用域,因为在销毁a时,对象将通过指向A的指针被删除,而且由于指向的对象是B,而且A的析构函数不是虚拟的,因此行为将是未定义的。解决方案:声明A::~A虚拟。
https://stackoverflow.com/questions/55446803
复制相似问题